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内 容 简 介 


本 书 共 12 章 , 从 介绍 静态 网 页 的 特点 及 其 设计 人 手 , 逐 步 对 网 页 布局 ,网 页 特效 技术 .C# 语 言 基础 、 
动态 网 页 布局 与 导航 、.NET 访问 数据 库 的 技术 等 进行 了 讲解 。 另 外 ,从 动态 网 站 设计 的 应 用 出 发 ,本 书 还 
集中 对 .NET 3. 5 技术 的 配置 .文档 设计 成员 资 格 管理 体系 ,信息 系 统 登 录 模块 的 实现 ,文件 上 传 与 管理 
技术 进行 了 介绍 。 最 后 ,本 书 介绍 了 动态 网 站 的 发 布 和 服务 器 配置 技术 ,保证 了 知识 体系 的 完备 性 。 

本 书 基于 任务 驱动 ,强化 案例 教学 ,在 简要 阐述 基本 原理 和 基本 技巧 的 前 提 下 ,通过 详细 地 讲授 具体 
案例 细 化 知识 与 技能 ,使 学 生 在 基于 案例 开展 实 训 、 应 用 知识 解决 问题 的 过 程 中 潜移默化 地 提高 动态 网 站 
开发 能 力 。 

本 书 适 于 作为 高 等 院 校 网 站 设计 、ASP.NET 编程 类 课程 的 教材 ,也 可 供 网 站 开发 人 员 人 参考。 
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洪 洒 地 沁 吕 类 徊 加 


随 着 我 国 改革 开放 的 进一步 深化 ,高 等 教育 也 得 到 了 快速 发 展 ,各 地 高 校 紧 密 结 合 地 方 
经 济 建设 发 展 需 要 ,科学 运用 市 场 调节 机 制 ,加 大 了 使 用 信息 科学 等 现代 科学 技术 提升 、 改 
造 传 统 学 科 专业 的 投入 力度 ,通过 教育 改革 合理 调整 和 配置 了 教育 资源 ,优化 了 传统 学 科 专 
业 , 积 极为 地 方 经 济 建设 输送 人 才 ,为 我 国 经 济 社会 的 快速 、 健 康 和 可 持续 发 展 以 及 高 等 教 
育 自身 的 改革 发 展 做 出 了 巨大 贡献 。 但 是 ,高 等 教育 质量 还 需要 进一步 提高 以 适应 经 济 社 
会 发 展 的 需要 ,不 少 高 校 的 专业 设置 和 结构 不 尽 合理 ,教师 队伍 整体 素质 亟待 提高 ,人 才 培 
养 模式 ,教学 内 容 和 方法 需要 进一步 转变 ,学 生 的 实践 能 力 和 创新 精神 或 待 加 强 。 

教育 部 一 直 十 分 重视 高 等 教育 质量 工作 。2007 年 1 月 ,教育 部 下 发 了 (关于 实施 高 等 
学 校本 科教 学 质量 与 教学 改革 工程 的 意见 》, 计 划 实 施 “ 高 等 学 校本 科教 学 质量 与 教学 改革 
工程 "(简称 “质量 工程 ”) ,通过 专业 结构 调整 ,课程 教材 建设 、 实 践 教学 改革 教学 团队 建设 
等 多 项 内 容 , 进 一 步 深化 高 等 学 校 教学 改革 ,提高 人 才 培 养 的 能 力 和 水 平 ,更 好 地 满足 经 济 
社会 发 展 对 高 素质 人 才 的 需要 。 在 贯彻 和 落实 教育 部 “质量 工程 ”的 过 程 中 ,各 地 高 校 发 挥 
师资 力量 强 、 办 学 经 验 丰富 ,教学 资源 充裕 等 优势 ,对 其 特色 专业 及 特色 课程 ( 群 ) 加 以 规划 、 
整理 和 总 结 , 更 新 教学 内 容 ,改革 课程 体系 ,建设 了 一 大 批 内 容 新 体系 新 .方法 新 .手段 新 的 
特色 课程 。 在 此 基础 上 ,经 教育 部 相关 教学 指导 委员 会 专家 的 指导 和 建议 ,清华 大 学 出 版 社 
在 多 个 领域 精 选 各 高 校 的 特色 课程 ,分 别 规划 出 版 系列 教材 ,以 配合 “质量 工程 ”的 实施 , 满 
足 各 高 校 教学 质量 和 教学 改革 的 需要 。 

为 了 深入 贯彻 落实 教育 部 (关于 加 强 高 等 学 校本 科教 学 工作 ,提高 教学 质量 的 若干 意 
见 ) 精 神 ,紧密 配合 教育 部 已 经 启动 的 “高 等 学 校 教学 质量 与 教学 改革 工程 精品 课程 建设 工 
作 ”, 在 有 关 专 家 、 教 授 的 倡议 和 有 关 部 门 的 大 力 支持 下 ,我 们 组 织 并 成 立 了 “清华 大 学 出 版 
社 教材 编审 委员 会 "(以 下 简称 “ 编 委 会 ”) , 旨 在 配合 教育 部 制定 精品 课程 教材 的 出 版 规划 ， 
讨论 并 实施 精品 课程 教材 的 编写 与 出 版 工作 。“ 编 委 会 "成员 皆 来 自 全 国 各 类 高 等 学 校 教学 
与 科研 第 一 线 的 骨干 教师 ,其 中 许多 教师 为 各 校 相关 院 、 系 主管 教学 的 院 长 或 系 主任 。 

按照 教育 部 的 要 求 ,“ 编 委 会 ”一致 认为 ,精品 课程 的 建设 工作 从 开始 就 要 坚持 高 标准 、 
严 要 求 ,处 于 一 个 比较 高 的 起 点 上 。 精 品 课程 教材 应 该 能 够 反映 各 高 校 教学 改革 与 课程 建 
设 的 需要 ,要 有 特色 风格 有 创新 性 (新 体系 .新 内 容 、 新 手段 .新 思路 ,教材 的 内 容 体系 有 较 
高 的 科学 创新 .技术 创新 和 理念 创新 的 含量 ) 先进 性 (对 原 有 的 学 科 体 系 有 实质 性 的 改革 和 
发 展 ,顺应 并 符合 21 世纪 教学 发 展 的 规律 ,代表 并 引领 课程 发 展 的 趋势 和 方向 ) .示范 性 ( 教 
材 所 体现 的 课程 体系 具有 和 较 广泛 的 辐射 性 和 示范 性 ) 和 一 定 的 前 瞻 性 。 教 材 由 个 人 申报 或 
各 校 推荐 (通过 所 在 高 校 的 “ 编 委 会 "成员 推荐 ) ,经 “ 编 委 会 ”认真 评审 ,最 后 由 清华 大 学 出 版 
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社 审定 出 版 。 
目前 ,针对 计算 机 类 和 电子 信息 类 相关 专业 成 立 了 两 个 “ 编 委 会 ”, 即 “清华 大 学 出 版 社 
计算 机 教材 编审 委员 会 "和 “清华 大 学 出 版 社 电子 信息 教材 编审 委员 会 "。 推 出 的 特色 精品 


教材 包括 : 

(1) 21 世纪 高 等 学 校规 划 教材 。 计算 机 应 用 一 一 高 等 学 校 各 类 专业 ,特别 是 非 计算 机 
专业 的 计算 机 应 用 类 教材 。 

(2) 21 世纪 高 等 学 校规 划 教材 ， 计算 机 科学 与 技术 一 一 高 等 学 校 计算 机 相关 专业 的 
教材 。 


(3) 21 世纪 高 等 学 校规 划 教材 。 电子 信息 一 一 高 等 学 校 电子 信息 相关 专业 的 教材 。 
(4) 21 世纪 高 等 学 校规 划 教材 。 软件 工 程 一 一 高 等 学 校 软 件 工程 相关 专业 的 教材 。 
(5) 21 世纪 高 等 学 校规 划 教材 。 信息 管 理 与 信息 系统 。 

(6) 21 世纪 高 等 学 校规 划 教材 财经 管理 与 应 用 。 

(7) 21 世纪 高 等 学 校规 划 教材 电子 商务 。 

(8) 21 世纪 高 等 学 校规 划 教材 。 物 联网 。 


清华 大 学 出 版 社 经 过 三 十 多 年 的 努力 ,在 教材 尤其 是 计算 机 和 电子 信息 类 专业 教材 出 
版 方面 树立 了 权威 品牌 ,为 我 国 的 高 等 教育 事业 做 出 了 重要 贡献 。 清 华 版 教材 形成 了 技术 
准确 内容 严谨 的 独特 风格 ,这 种 风格 将 延续 并 反映 在 特色 精品 教材 的 建设 中 。 


清华 大 学 出 版 社 教材 编审 委员 会 
联系 人 : 魏 江 江 


E-mail: weijj@ tup. tsinghua. edu. cn 


随 着 因特网 的 普及 ,基于 因特网 的 电子 商务 .电子 政务 活动 日 益 频繁 ,因特网 在 教育 中 
也 发 挥 着 不 可 蔡 代 的 作用 。 可 以 说 ,因特网 改变 了 一 个 时 代 。 基 于 此 ,依托 动态 网 站 开发 技 
术 而 鞍 勃 发 展 的 Browser/Server(B/S) 模 式 的 信息 系统 占据 了 当前 企 事业 管理 平台 的 绝 大 
多 数 份额 , 企 事业 单位 对 信息 系统 的 应 用 水 平 将 直接 影响 着 它们 的 工作 效率 ,成 为 反映 其 管 
理 水 平 的 重要 标志 。 因 此 ,在 强大 的 社会 需求 和 因特网 技术 高 速 发 展 的 驱动 下 ,动态 网 站 开 
发 技术 进入 到 了 一 个 百花 齐 放 , 万 马 奔腾 的 高 速 发 展 时 期 。 在 这 一 历史 形势 下 ,表现 最 为 突 
出 的 动态 网 站 开发 技术 有 JSP.ASP.NET 和 PHP。 作 为 Java 技术 在 动态 网 页 开发 领域 的 
重要 代表 ,JSP 技术 以 其 效率 高 .路 平 台 而 深 受 企 事 业 信 息 系 统 建设 者 的 青睐 ;而 基于 
Windows 系列 平台 的 ASP.NET 技术 则 以 “与 Windows 平台 无 颖 连接 、 功 能 强大 、 易 于 学 
习 ” 而 被 广泛 地 应 用 ; PHP 技术 发 源 于 Linux 平台 , 因 其 开源 和 共享 而 深 受 在 校 大 学 生 和 
中 小 企业 的 喜爱 。 对 比 三 种 技术 并 纵 观 其 发 展 史 , 可 以 说 三 者 各 有 其 独特 优势 。 基 于 此 ,本 
书 选择 了 Microsoft 的 .NET Framework 3.5, 以 C# 作 为 开发 语言 ,探讨 动态 网 站 的 开发 
技术 。 

作为 多 年 从 事 教育 管理 信息 系统 建设 的 教师 ,通过 多 年 的 系统 开发 和 教学 实践 ,笔者 深 
刻 地 认识 到 :“ 工 欲 善 其 事 , 必 先 利 其 器 ,” 也 就 是 说 ,在 动态 网 站 的 开发 过 程 中 ,选择 合适 的 
开发 工具 充分 利用 系统 提供 的 集成 化 控件 ,可 以 “事半功倍 ”。 以 .NET 技术 中 访问 SQL 
Server 数据 库 的 技术 为 例 ,在 .NET 的 1.1 版 本 下 ,主要 通过 SqlCommand 实现 数据 库 操 
作 。 在 这 一 技术 中 ,如 果 要 实现 网 页 界面 输入 内 容 与 后 台数 据 库 交互 的 功能 ,就 必须 撰写 
SQL 语句 并 使 用 参数 设计 与 参数 绑 定 技术 。 另 外 ,对 象 SqlCommand 的 应 用 必须 建立 在 数 
据 库 连接 的 基础 上 , 即 在 执行 SqlCommand 命令 前 必须 建立 有 效 的 数据 库 连 接 对 象 。 在 这 
个 过 程 中 ,开发 者 常常 要 面临 三 个 难点 : 其 一 ,因数 据 库 连 接 字符 串 书写 格式 问题 而 导致 数 
据 库 连接 失败 ; 其 二 ,SQL 语句 书写 错误 ; 其 三 ,为 SqlCommand 绑 定 参 数 时 常常 因 类 型 和 
格式 问题 而 惨遭 失败 。 这 些 难点 成 为 很 多 初学 者 迈 人 ASP.NET 门槛 的 拦路 虎 。 然 而 , 自 . 
NET 3.5 提供 了 SqlDataSource 控件 和 LINQ 技术 后 ,这 些 难 点 就 自动 消失 了 。VS2008 的 
“服务 器 资源 管理 器 * 和 “LINQ to SQL 类 ”为 开发 者 提供 了 一 个 可 视 化 的 界面 ,使 开发 人 员 
能 够 利用 鼠标 便捷 地 把 数据 表 从 “服务 器 资源 管理 器 ”" 拖 动 到 窗 体 中 , 自动 地 创建 
SqlDataSource 对 象 , 从 而 实现 了 “无 编码 操作 数据 库 ” 的 目标 。 其 实 , 在 借助 JSP 技术 开发 
动态 网 站 的 过 程 中 ,笔者 也 有 同样 的 感触 : 在 JSP 技术 兴起 初期 ,作为 教师 的 笔者 常常 为 如 
何 才 能 向 学 生 讲 清楚 Servlet 和 Struts 技术 中 的 众多 配置 文件 .配置 选项 及 其 存储 位 置 而 
烦恼 。 然 而 , 当 MyEclipse 和 JBuilder 等 开发 工具 出 现 后 ,这 些 配置 文件 中 的 绝 大 多 数 内 容 
都 可 由 开发 工具 自动 生成 , 极 大 地 提升 了 开发 效率 ,减少 了 学 习 难 度 。 因 此 笔者 认为 : 作为 
讲授 动态 网 站 开发 技术 的 教材 ,应 该 尽 可 能 向 大 家 介绍 新 控件 的 应 用 , 尽 最 大 的 可 能 减少 代 
码 的 使 用 量 , 争 取 在 可 视 化 界面 下 依托 新 控件 的 功能 ,借助 尽量 精炼 的 代码 完成 以 往 需 要 大 
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量 编码 才能 实现 的 业务 需求 。 为 此 ,本 书 中 较为 详细 地 讲授 了 SqlDataSource 控件 和 
GridView 控件 的 使 用 ,并 对 LINQ 的 用 法 进行 了 比较 详细 的 介绍 。 

本 教材 采取 了 “直接 从 应 用 入 手 设计 课程 体系 ”的 方案 ,结合 教育 的 规律 .特点 和 大 家 急 
需 利用 .NET 技术 实现 动态 网 站 并 获得 成 功 体 验 的 要 求 ,以 任务 驱动 为 主线 ,大 量 组 织 案 
例 , 在 案例 的 设计 开发 过 程 中 构建 出 相对 完整 的 知识 体系 。 全 书 共 分 为 12 章 ,从 介绍 静态 
网 页 的 特点 及 其 设计 入 手 , 逐 步 对 网 页 布局 .C# 语言 基础 ,动态 网 页 布局 与 导航 、.NET 访 
问 数 据 库 的 技术 进行 了 讲解 ,并 通过 具体 案例 的 实施 ,使 学 习 者 能 够 较为 全 面 地 掌握 相关 技 
术 。 另 外 ,从 动态 网 站 设计 的 具体 应 用 出 发 ,本 教材 还 集中 对 .NET 技术 的 成 员 资格 管理 体 
系 、 登 录 模 块 的 实现 ,文件 的 上 传 与 管理 技术 进行 了 讲解 ,并 以 案例 的 形式 展示 了 把 文件 上 
传 到 文件 夹 与 数据 库 内 的 具体 方法 。 最 后 ,本 书 讲授 了 动态 网 站 的 发 布 和 服务 器 配置 技术 ， 
保证 了 知识 体系 的 完备 性 。 

与 传统 的 同类 书籍 相 比 ,在 案例 的 选择 方面 ,本 书 注重 了 案例 的 多 样 性 和 典型 性 ; 在 系 
统 开发 方面 ,注重 讲授 控件 的 使 用 ,对 于 一 些 能 够 通过 集成 控件 实现 的 功能 ,尽量 通过 集成 
控件 完成 ,并 完整 地 描述 其 实现 过 程 ,减少 开发 过 程 中 代码 的 使 用 量 , 以 便 大 家 掌握 通过 
.NET 3.5 的 内 置 控 件 快速 构造 模块 的 技巧 ; 在 程序 编码 方面 , 则 注意 补充 提示 信息 ,以 便 
于 大 家 理解 程序 ,有 利于 大 家 在 实践 和 理解 中 提高 。 本 书 中 所 有 案例 的 程序 都 遵循 “从 浅 到 
深 ,以 解决 实际 问题 为 导向 "的 原则 ,使 读者 在 模仿 教材 案例 的 过 程 中 ,潜移默化 地 提高 动态 
网 站 开发 能 力 。 

本 书 的 成 形 得 益 于 多 方面 的 帮助 ,首先 是 在 成 书 过程 中 参考 了 大 量 的 文献 ,对 这 些 文献 
的 作者 表示 衷心 的 谢意 。 同 时 ,清华 大 学 出 版 社 的 付 弘 宇 老师 对 本 书 的 出 版 给 予 了 自 始 至 
终 的 关心 和 指导 ,并 提出 了 许多 中 肯 的 意见 ,在 此 对 清华 大 学 出 版 社 表示 衷心 地 感谢 。 

虽然 笔者 尽力 想 把 本 书写 好 ,然而 由 于 阅历 所 限 , 难 免 存 在 一 些 问 题 ,特别 是 由 于 篇 幅 所 
限 ,不 可 能 对 每 个 案例 的 代码 进行 全 面 的 详细 分 析 , 希 望 大 家 谅解 。 对 于 书 中 存在 的 问题 , 欢 
迎 大 家 探讨 ,并 欢迎 针对 本 书 提出 宝贵 的 建议 。 编 者 的 Email: maxl@bnu. edu. cn。 

本 书 的 配套 资源 (包括 电子 课件 、 书 中 实例 源 代码 等 , 近 300MB) 可 以 从 清华 大 学 出 版 
社 网 站 www. tup. com. cn 下 载 ,本 书 及 课件 的 使 用 问题 请 联系 fuhy @ tup. tsinghua. 
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学 习 要 点 

本 章 主要 学 习 静 态 网 页 设计 的 关键 技术 ,要 求 了 解 网 页 的 基本 概念 、 网 页 设计 的 主要 技 
术 、 网 页 布局 方法 、 网 页 设计 中 常见 的 说 入 式 语言 。 本 章 重 点 关注 以 下 内 容 : 

。 HTML 文档 的 结构 及 其 主要 标记 。 

。 网 页 布局 方法 ,重点 关注 以 Photoshop 实施 层 布 局 的 方法 .CSS 文档 的 概念 及 作用 。 

。 网 页 中 的 行为 动画 技术 。 

。 网 页 中 嵌入 JavaScript 语句 的 方法 和 常用 的 JavaScript 语句 。 


(1.1 网 页 基础 知识 


1.1.1 网 页 文件 


1, 网 页 文件 含义 

网 页 在 英语 中 称 为 homepage, 也 称 为 WWW 网 页 ,网 页 内 容 包括 文字 声音、 图 片 等 ， 
其 目的 是 把 一 定量 的 信息 和 图 片 按照 一 定 的 形式 显示 在 计算 机 屏幕 上 ; 同时 ,为 了 满足 
Internet 系统 的 需要 ,网 页 中 还 应 该 包含 页 面 指针 ,使 计算 机 系统 能 够 很 容易 地 由 一 个 页 面 
调用 另 一 个 页 面 文 件 。 网 页 指针 既 可 以 指向 本 地 计算 机 上 的 另 一 个 网 页 文件 ,也 可 以 指向 
另 一 台 提 供 WWW 服务 的 计算 机 上 某 文件 夹 中 的 另 一 个 网 页 文件 。 

网 页 文件 的 文件 名 可 以 随意 规定 ,就 像 规定 其 他 类 型 的 文件 名 称 一 样 ,其 扩展 名 则 是 
“htm” 或 “html”。 网 页 文件 的 内 容 应 该 由 特定 的 语句 构成 ,这 些 语句 说 明 本 页 面 中 应 该 包 
含 娜 些 文本 内 容 , 包 含 哪些 图 片 文件 ,以 及 这 些 图 片 和 文本 在 浏览 器 中 的 显示 格式 。 同 时 ， 
本 页 面 还 应 该 链接 哪些 页 面 文件 ,能 够 保证 用 户 从 这 个 页 面 进入 另 一 个 页 面 。 这 些 功 能 都 
需要 由 HTML 的 特定 的 语句 组 成 。 

当然 ,为 了 使 页 面 美观 漂亮 ,页 面 中 还 应 该 包含 对 屏幕 背景 的 设 定 和 页 面 内 容 位 置 分 布 
的 安排 。 较 早期 的 页 面 设计 必须 使 用 HTML 语句 书写 ,页 面 设 计 者 必须 像 编写 程序 一 样 
通过 书写 语句 来 控制 屏幕 内 容 的 色彩 ,布局 .字形 和 字体 等 ,以 争取 达到 完美 的 效果 。 以 这 
种 非 所 见 即 所 得 的 形式 设计 网 页 通常 是 一 种 效率 低下 的 工作 。 

随 着 计算 机 软件 技术 的 发 展 ,现在 已 经 有 了 许多 网 页 书写 工具 ,使 我 们 可 以 像 进行 文字 
处 理 一 样 书写 自己 的 网 页 文件 。 目 前 比较 著名 的 网 页 设计 工具 有 Microsoft 公司 Office 套 
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件 中 的 FrontPage 系统 和 Macromedia 公司 的 Dreamweaver 系统 (该 系统 现在 已 经 被 
Adobe 公司 收购 ) 。 

2. 网 页 文件 特点 及 构成 

1) 网 页 文件 的 基本 特点 

网 页 文件 是 以 超 文本 的 形式 向 浏览 者 呈现 信息 。 因 此 , 它 表现 为 三 个 特性 。 

(1) 多 媒体 特点 

人 允许 在 一 个 网 页 内 集中 多 种 信息 形态 : 文本 图像 ,图形 动画、 视频 等 元 素 ,这 些 元 素 
被 按照 一 定 的 格式 组 织 起 来 。 因 此 网 页 具有 多 媒体 的 特点 。 

(2) 超 链 接 

作为 Internet 信息 的 重要 呈现 方式 ,网 页 必须 支持 从 一 个 页 面 链 接 到 另外 一 个 页 面 ,而 
且 为 了 提高 网 页 的 传输 效率 ,网 页 对 隶属 于 自身 的 多 媒体 对 象 也 采取 了 链接 方式 。 超 链接 
是 网 页 的 另 一 个 重要 特征 。 

(3) 相对 路 径 

为 了 能 够 把 网 页 文件 主体 与 其 内 部 元 素 有 机 地 结合 在 一 起 ,在 网 页 内 部 链接 其 他 文件 
时 ,要 统一 使 用 相对 路 径 ,从 而 保证 在 网 页 被 整体 移动 到 其 他 位 置 时 ,不 因 链 接 位 置 错误 而 
导致 网 页 出 现 故 障 。 

2) 网 页 文件 的 构成 

一 个 网 页 通常 由 多 个 文件 构成 ,其 中 . htm 文件 中 包含 文本 资料 .控制 语句 和 格式 信息 ; 
而 网 页 中 包含 的 图 像 动画 等 都 以 链接 方式 与 . htm 文件 发 生 联 系 。 因 此 一 个 网 页 通常 由 一 
个 . htm 或 . html 文件 和 多 个 图 像 文 件 ,动画 文件 组 成 ,而 . htm( 或 . html) 文 件 起 到 统帅 和 组 
织 作用 。 

为 保证 文件 的 链接 不 因 网 页 改变 存储 位 置 而 出 现 链接 错误 ,在 . htm( 或 . html) 文 件 中 
对 图 像 文件 ,动画 文件 的 链接 应 该 使 用 相对 路 径 ,不 能 带 有 盘 符 。 

3. 网 页 布局 

网 页 设计 的 核心 问题 就 是 解决 文本 、 图 片 . 动 画 等 在 浏览 器 中 的 样式 、 排 列 与 摆 放 位 置 
的 问题 。 因 此 网 页 布局 是 网 页 设计 的 关键 问题 。 

传统 的 网 页 布局 主要 通过 表格 实现 布局 ,当前 的 网 页 设计 则 主要 通过 样式 文件 和 层 实 
现 布局 , 称 为 CSS 十 DIV 布局 。 

1) 表格 布局 

在 页 面 上 插入 一 个 表格 ,然后 通过 划分 每 个 单元 格 的 大 小 和 位 置 把 屏幕 分 为 几 个 区 域 ， 
实现 页 面 布局 。 其 缺陷 在 于 : 如 果 单 元 格 中 的 内 容 过 多 ,可 能 导致 单元 格 被 撑 开 、 撑 大 , 进 
而 导致 整个 布局 被 撑 散 。 

2) 层 布局 

层 布 局 即 利用 层 实 现 布局 ,基本 思想 是 在 页 面 上 绘制 多 个 层 对 象 ,并 通过 CSS 样式 限 
定 每 个 层 对 象 的 宽度 ,高度 和 绝对 位 置 。 在 这 种 思想 下 ,屏幕 被 划分 为 若干 个 位 于 不 同位 置 
的 区 域 ( 层 ) ,用 户 可 以 向 每 个 区 域 中 输入 内 容 。 

在 网 页 布局 完成 后 ,就 可 以 向 网 页 的 各 个 布局 区 域 中 插入 文本 、 图 形 、 图 像 等 网 页 所 需 
的 各 种 对 象 了 。 


第 1 章 ”网 页 设计 基础 


1.1.2 网 页 下 常见 的 嵌入 式 语 言 


1. 网 页 下 为 什么 要 使 用 嵌入 式 语言 ? 

早期 的 网 页 仅仅 是 为 了 呈现 文本 和 图 像 信息 ,因此 其 控制 符号 比较 简单 。 然 而 随 着 互 
联网 的 普及 ,人 类 对 网 页 功能 的 要 求 逐 渐 增 多 ,主要 表现 为 两 个 方面 : 其 一 ,在 网 页 上 实现 
特殊 的 显示 效果 ,诸如 弹出 窗口 . 跑 动 的 广告 图 片 ,动态 显示 当前 日 期 \ 时 间 等 效果 ; 其 二 ， 
利用 网 页 实现 远程 交互 ,诸如 通过 网 页 提交 数据 (网 络 调查 、 网 上 订购 物品 ) 、 利 用 网 络 查 询 
数据 等 的 功能 。 因 此 ,在 网 页 设计 中 ,逐渐 允许 在 HTML 语句 中 嵌入 一 些 脚本 语言 ,实现 
特殊 的 控制 功能 。 

2. 客户 端 运 行 的 嵌入 式 语 言 

为 实现 网 页 特效 而 嵌入 的 语句 被 服务 器 直接 发 送 到 客户 端的 浏览 器 ,由 客户 端的 浏览 
器 负责 执行 其 中 的 代码 。 这 种 语句 称 为 客户 端 运 行 的 嵌入 式 语 言 。 

运行 于 客户 端的 庶 入 式 语言 都 是 脚本 型 语言 ,主要 有 JavaScript 和 VBScript。 在 网 页 
中 以 二 Script language 一 JavaScript 二 二 /Script 过 或 者 二 Script language 王 VBScript 二 
去 /Script> 标 志 , 其 语法 接近 于 Java 语言 和 VB 语言 。 

目前 ,网 页 中 的 绝 大 多 数 的 特效 都 是 由 运行 于 客户 端的 JavaScript 语句 实现 的 。 

3, 服务 器 端 运行 的 嵌入 式 语言 

在 互联 网 的 应 用 中 ,电子 商务 、 电 子 政务 和 信息 系统 的 发 展 要 求 Web 服务 器 能 够 利用 
网 页 收集 数据 并 把 数据 存储 到 服务 器 中 ,同时 还 要 求 远程 用 户 能 够 通过 网 页 浏览 .查询 相关 
数据 。 这 些 工作 都 需要 后 台数 据 库 的 支持 ,同时 要 求 Web 服务 器 能 够 运行 一 些 特定 的 语 
名 ,实现 向 数据 库 中 存储 数据 和 提取 数据 的 功能 。 基 于 此 ,运行 于 服务 器 端的 嵌入 式 语言 出 
现 了 。 

对 于 运行 于 服务 器 端的 嵌入 式 语 言 来 说 , Web 服务 器 在 接 到 客户 的 访问 请 求 时 会 在 服 
务 器 上 执行 网 页 中 包含 的 ASP 语句 ,并 把 执行 结果 发 送 到 客户 端的 浏览 器 中 。 因 此 客户 端 
用 户 无 法 看 到 这 种 嵌入 式 语言 的 源 程序 ,只 能 获得 其 执行 结果 。 

运行 于 服务 器 端的 嵌入 式 语 言 的 出 现 ,为 互联 网 的 应 用 开辟 了 一 个 广阔 的 领域 ,使 网 页 
设计 向 基于 后 台数 据 库 的 动态 网 站 方向 发 展 。 在 此 基础 上 ,基于 浏览 器 的 各 种 信息 系统 、 网 
上 销售 系统 ,电子 政务 等 莲 勃 发 展 ,出 现 了 新 一 代 的 信息 系统 一 Browser/Server 模式 ( 浏 
览 器 /服务 器 模式 ,简称 为 B/S 模式 ) 的 信息 系统 。 这 种 建立 在 动态 网 站 技术 上 的 信息 系统 
已 经 渗透 到 商业 ,企业 ,管理 .教育 等 诸多 领域 ,成 为 当前 信息 系统 的 主流 。 

目前 可 嵌入 到 HTML 语言 下 的 程序 语言 很 多 ,应 用 得 比较 广泛 的 有 以 下 4 种 。 

1) ASP 技术 

ASP 技术 是 微软 公司 的 产品 ,运行 在 微软 的 IIS 服务 器 上 ,其 语句 以 “二 % % 过 ”标志 ， 
其 语言 基础 是 Visual Basic 或 Java, 对 应 的 开发 语言 是 VBScript 和 JavaScript。 使 用 了 
ASP 技术 的 网 页 文件 以 asp 作为 扩展 名 。 

ASP 语句 执行 在 服务 器 端 ,是 一 种 脚本 语言 ,其 语句 可 以 零散 地 嵌入 到 HTML 文档 的 
任意 位 置 ,为 程序 开发 提供 了 极 大 的 灵活 性 。 但 也 正 是 这 种 灵活 性 ,导致 ASP 语句 分 散 出 
现在 HTML 文档 中 ,束缚 了 其 在 大 型 项 目 中 的 应 用 ,也 限制 了 其 运行 效率 。 

ASP 因 其 简单 性 和 便利 性 ,曾经 占据 动态 网 站 开发 50% 以 上 的 市 场 ,能 够 完成 网 页 访 


3 


Aé 


4 


Nt 


动态 网 站 设计 与 开发 (ASP. NET 版 ) 


问 计数 器 .操作 后 台数 据 库 ( 保 存 表单 数据 .查询 数据 表 内 容 ) 等 常规 功能 。 

2) ASP.NET 技术 

ASP.NET 是 在 ASP 基础 上 发 展 起 来 的 一 种 嵌入 式 语言 ,也 是 微软 公司 的 产品 ,运行 
在 “IIS 服务 器 十 . Net Framework 框架 ”的 基础 上 。ASP .NET 支持 3 种 开发 语言 : Visual 
Basic、.C++ 和 C#。 

与 ASP 相 比 ,ASP.NET 的 开发 语言 代码 要 相对 独立 于 HTML 文档 ,ASP.NET 不 多 
许 在 HTML 标记 之 间 随 意 地 嵌入 其 语句 , 它 必 须 以 模块 的 方式 嵌入 到 网 页 中 。 在 ASP . 
NET 开发 体系 下 ,开发 人 员 可 以 在 网 页 开始 处 嵌入 一 个 代码 模块 ,也 可 以 另外 建立 一 个 独 
立 的 文件 ,用 于 存放 ASP.NET 的 开发 语言 代码 。 

ASP.NET 克服 了 ASP 因 嵌 入 代码 位 置 过 度 灵活 而 导致 的 缺陷 ,体现 了 一 种 真正 的 面 
向 对 象 的 程序 开发 思想 ,并且 实现 了 界面 设计 与 编码 设计 的 分 离 , 为 大 型 项 目的 开发 提供 了 
有 力 的 支持 。ASP.NET 技术 是 目前 动态 网 站 开发 的 主流 技术 之 一 。 

3) PHP 技术 

PHP 技术 起 源 于 免费 的 Linux 平台 ,通常 与 MySQL 数据 库 管理 系统 配合 使 用 ,服务 
于 动态 网 站 开发 。 目 前 ,在 Windows 系列 服务 器 上 ,也 有 支持 PHP 技术 的 插件 。 

PHP 语句 以 “<?? 之 标志 ?执行 在 服务 器 端 , 也 是 一 种 脚本 语言 。 这 种 语言 在 大 学 生 
中 间 有 较 多 的 拥护 者 。 使 用 了 PHP 技术 的 网 页 文件 以 php 作为 其 扩展 名 。 

4) JSP 技术 

JSP 技术 是 基于 Java 语言 的 动态 网 页 开发 技术 ,其 语法 以 Java 为 基础 ,能 够 完成 大 型 
信息 系统 的 开发 ,在 动态 网 站 设计 领域 也 有 卓越 的 表现 。 目 前 JSP 技术 在 电子 政务 .电子 
商务 等 信息 系统 开发 中 有 着 广泛 的 应 用 和 重要 的 影响 。 使 用 了 JSP 技术 的 网 页 文件 以 jsp 
作为 其 扩展 名 。 


1.1.3 网 页 设计 技术 


1. 基础 知识 

从 网 页 的 构成 看 ,网 页 包括 文本 图像、 图片 动画、 视频 、 超 链接 等 组 成 方式 ,网 页 的 编 
写 以 HTML 语言 实现 。 

在 网 页 设计 中 ,对 页 面 实施 布局 并 恰当 地 设置 页 面 属性 ,调整 页 面 的 背景 ,优化 整个 网 
页 ,然后 再 插入 所 需 的 各 种 文本 、 图 像 或 图 片 等 网 页 元 素 , 以 和 谐 的 界面 呈现 各 种 信息 。 

在 网 页 设计 时 ,如 果 仅 仅 用 于 信息 发 布 ,而 且 信 息 变化 不 是 非常 频繁 , 则 可 以 使 用 静态 
页 面 设 计 。 对 于 页 面 信息 变化 频繁 ,交互 性 很 强 的 页 面 ,通常 需要 使 用 动态 页 面 开发 技术 ， 
借助 “后 台数 据 库 十 管理 程序 ?开发 动态 网 站 。 

目前 ,主流 的 静态 网 页 设计 语言 是 HTML 语言 (Hypertext Markup Language， 
HTML) ,而 要 开发 动态 网 页 , 则 需要 使 用 专门 的 动态 网 页 开发 语言 实施 开发 ,例如 使 用 
ASP.NET 开发 动态 网 站 。 但 是 ,即便 是 动态 网 页 开发 ,也 建立 在 静态 网 页 设计 技术 的 基础 
上 ,静态 网 页 设计 中 使 用 的 方法 、 技 能 等 在 动态 网 页 开发 中 仍然 有 效 。 

2. 网 页 设计 流程 

(1) 需求 分 析 。 明 确 需求 ,确定 网 站 的 设计 目标 ,了 解 其 主要 构成 成 分 内容、 规模 。 


第 1 章 ”网 页 设计 基础 


(2) 准备 素材 。 根 据 需 求 ,准备 各 种 素材 ,组 织 相关 的 文字 材料 .图像 .图片 .动画 等 ,并 
对 图 像 ,图 片 ,动画 等 素材 进行 预 处 理 。 

(3) 确定 基调 与 风格 。 确 定 网 页 的 基调 、 风 格 ,并 根据 网 页 的 设计 目标 绘制 草图 ,形成 
初步 的 页 面 框架 图 。 

(4) 网 页 布局 。 根 据 规划 的 基调 、 风 格 和 草图 ,利用 Photoshop 等 软件 实现 网 页 布局 ， 
生成 Web 页 面 文档 。 

(5) 制作 模板 ( 母 版 )。 利 用 Photoshop 等 软件 的 布局 结果 ,在 Dreamweaver 或 Visual 
Studio 2008 等 系统 中 制作 模板 ( 母 版 ) 页 ,为 批量 制作 网 页 做 好 准备 。 

(6) 创建 内 容 页 。 利 用 Dreamweaver 或 Visual Studio 2008 等 系统 ,根据 母 版 创建 内 容 
页 ,并 进行 必要 的 程序 编码 ,然后 运行 与 测试 内 容 页 。 

(7) 系统 整体 测试 。 当 全 部 内 容 页 都 设计 完成 后 ,需要 对 整个 站 点 的 网 页 进行 整体 测 
试 ,重点 检查 页 面 之 间 的 超 链接 是 否 正常 ,参数 传递 是 否 无 误 。 其 目标 是 消灭 死 链 \、 错 误 链 
接 , 保 证 系统 的 整体 性 能 。 

(8) 网 页 发 布 。 通 过 整体 测试 后 ,就 可 以 发 布 网 站 了 。 即 把 网 站 所 包含 的 全 部 页 面 发 
布 到 专门 的 Web 服务 器 上 , 供 广 大 用 户 访问 、 浏 览 。 


(3 Dreamweaver 与 网 页 设计 


Dreamweaver 和 FrontPage 是 两 个 非常 著名 的 网 页 设计 软件 。 其 中 Dreamweaver 是 
Macromedia 公司 (已 被 Adobe 公司 收购 ) 的 产品 , 因 功 能 全 面 而 深 受 网 页 设计 人 员 的 喜爱 。 
FrontPage 是 Microsoft 公司 的 产品 , 因 其 与 Windows 系统 和 IE 浏览 器 有 较 好 的 兼容 性 而 
被 广泛 地 使 用 。 

本 节 将 以 Dreamweaver 8. 0 为 例 简要 介绍 静态 网 页 设计 的 主要 技术 。 为 便于 阐述 ,本 
书 将 Dreamweaver 简称 为 DW。 


1.2.1 DW 设计 网 页 的 必要 准备 


1. 安装 与 启动 

作为 一 个 运行 于 Windows 平台 的 网 页 设计 软件 ,其 安装 过 程 与 其 他 的 Windows 应 用 
软件 没有 不 同 , 主 要 包括 以 下 两 个 步 又: 下 载 软件 ,阅读 说 明 ; @ 双 击 SETUP. EXE 启动 
安装 过 程 ,按照 系统 提示 逐步 安装 。 

在 DW 安装 过 程 中 需要 提供 序列 号 ,新 版 本 需要 激活 ,否则 只 有 1 个 月 的 试用 期 限 。 

鉴于 在 新 版 本 的 DW CS4 中 取消 了 很 有 特色 的 时 间 轴 功能 ,本 教材 暂时 以 DW 8. 0 为 
例 讲述 DW 的 使 用 。 

要 启动 DW ,可 以 通过 Windows 的 “开始 ”菜单 ,或 者 使 用 Windows 桌面 的 快捷 方式 
启动 。 
2. 熟悉 DW 主 界面 
启动 DW, 进 入 到 其 主 界面 工作 方式 下 。 其 界面 如 图 1-1 所 示 。 
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OMacromedia Dreanweaver 8 - [Untitled-l (XHTML)] 


图 1-1 DW 主 界面 


1) 工具 栏 

工具 栏 位 于 DW 窗口 的 菜单 栏 下 ,上 图 中 标记 为 “1” 的 位 置 。 工 具 栏 有 多 种 类 型 ,开发 
者 可 根据 需要 选用 所 需 的 工具 栏 。“ 插 入 ”工具 栏 中 有 项 目 “ 常 用 ”“ 布 局 ”“ 表 单 ”“ 文 本 ”、 
“HTML” 等 。 选 择 不 同 的 类 别 ,将 会 使 整个 工具 栏 呈现 不 同 的 序列 。 

利用 系统 菜单 【查看 >【 工 具 栏 ] 可 以 显示 或 隐藏 工具 栏 。 

2) 面板 

DW 的 最 大 特色 就 是 提供 了 丰富 的 面板 。 图 中 “3”“4”“5”、“6” 标 记 的 区 域 都 是 面板 。 
其 中 *4” 是 [属性 ] 面 板 ,“6” 为 【时间 轴 面板 ,“5” 为 [行为 面板 ,“3” 处 是 [CSS 样式 ] 面 板 。 

其 中 ,【 属 性] 面板 主要 用 于 设置 各 类 对 象 的 属性 ;【 行 为 面板 主要 为 对 象 设置 特定 的 
行为 ,使 对 象 在 遭受 某 些 事件 时 给 予 一 些 响应 。 例 如 在 窗 体 调和 时 弹出 窗口 ,在 按钮 被 单 击 时 
关闭 当前 窗口 ,等 等 。 另 外 ,还 有 【CSS 样式 ]【 时 间 轴 等 面板 ,分 别 可 以 完成 对 应 的 功能 。 

通过 DW 系统 顶部 的 菜单 [窗口 〗, 可 以 实现 单个 面板 的 “展开 ”与 “关闭 ”, 还 可 以 通过 
F4 键 实施 全 体面 板 的 展开 与 隐藏 。 

3) 设计 方式 与 代码 方式 

通过 菜单 [查看 ] 中 的 [代码 ] 或 [设计 】, 可 以 分 别 以 网 页 “ 源 代码 ”方式 或 “设计 ”方式 查 
看 网 页 效果 ,甚至 可 以 在 网 页 源 代码 方式 下 直接 修改 HTML 语句 。 

3. 以 DW 设计 网 页 的 流程 

以 DW 设计 网 页 ,需要 首先 启动 DW 系统 ,然后 创建 一 个 站 点 ,用 于 对 即将 创建 的 网 页 
及 其 内 容 统 一 管理 。 然 后 按照 以 下 步骤 实施 操作 。 

(1) 选择 菜单 [文件 >【 新 建 ]>【 基 本 页 ->HTML ,然后 单 击 【创建 ] 按 钮 , 即 可 新 建 一 
个 网 页 文件 ,进入 到 页 面 创建 状态 。 

(2) 利用 各 种 布局 技术 ,对 页 面 进行 统一 规划 ,实施 页 面 布局 。 

(3) 向 网 页 中 插入 各 种 对 象 。 

(4) 预览 已 设置 网 页 的 效果 。 
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(5) 如 果 网 页 已 经 符合 要 求 , 可 发 布 网 页 并 在 服务 器 上 测试 网 页 的 性 能 。 

4. 创建 Web 站 点 

1) 创建 Web 站 点 的 原因 

在 DW 设计 网 页 前 ,应 该 创建 一 个 站 点 。 使 用 站 点 ,具有 以 下 优势 ， 

(1) 使 用 站 点 ,可 以 实现 对 网 页 文件 的 统一 管理 。 也 就 是 说 ,通过 站 点 ,能 够 保证 在 网 
页 设计 过 程 中 ,DW 会 自动 地 把 不 在 站 点 下 的 文件 统一 复制 到 站 点 文件 夹 中 ,避免 在 网 页 发 
布 时 因 文件 分 散 存 放 而 出 现 遗 漏 个 别 文件 的 现象 。 

(2) 使 用 站 点 ,可 以 保证 对 引用 对 象 使 用 相对 路 径 , 避 免 在 网 页 中 出 现 绝对 路 径 ,从 而 
减少 死 链 和 错 链 现象 。 

(3) 使 用 站 点 后 ,在 DW 中 可 以 创建 并 使 用 模板 ,然后 利用 模板 批量 创建 网 页 ,提高 网 
页 的 生成 与 编辑 效率 。 

2) 创建 站 点 的 方法 

利用 菜单 [站 点 了 并 管理 站 点 了 ,打开 【管理 站 点 】 对 话 框 ， 
如 图 1-2 所 示 。 

单 击 [ 新 建 ] 按 钮 ,然后 选择 “站 点 ”, 为 站 点 命名 并 指向 本 
地 计算 机 上 的 一 个 空白 文件 夹 。 

通过 上 述 操作 , 即 可 创建 一 个 站 点 ,使 新 建 的 全 部 网 页 及 


其 链接 的 文档 都 存储 在 这 个 站 点 中 ( 即 那个 空白 文件 夹 中 )， 

以 便于 未 来 的 站 点 复制 或 网 页 发 布 。 图 1-2 【管理 站 点 对话 杠 
1.2.2 简单 页 面 设计 
1. 插入 文本 


在 以 DW 设计 网 页 过 程 中 ,向 网 页 中 插入 文本 非常 简单 ,可 以 直接 在 页 面 上 输入 文本 。 

如 果 需 要 把 文本 插入 到 网 页 中 的 特定 位 置 , 则 可 以 先 插入 一 个 表格 。 利 用 表格 实施 定 
位 ,然后 再 在 适当 的 单元 格 中 输入 文字 。 

如 果 需 要 设置 文字 的 格式 ,通常 不 直接 设置 字形 .字号 等 内 容 ,而 是 使 用 预先 定义 的 样 
式 , 利 用 样式 实现 文本 格式 的 设置 。 关 于 样式 的 问题 ,将 会 在 后 面 的 1. 3. 1 节 中 讲述 。 

2. 插入 静态 图 片 

在 网 页 设计 中 ,把 插入 点 光标 放 在 需要 插入 图 片 的 位 置 ,选择 系统 菜单 [插入 】 一 
【图 像 】, 然 后 在 [打开 文件 对 话 框 中 选择 图 片 文件 ,系统 将 会 把 图 片 插入 到 当前 位 置 处 。 

图 片 插入 后 ,底部 的 [属性 ] 面 板 将 变 成 图 片 的 [属性 面板 。 通 过 此 面板 ,可 以 修改 图 片 
的 大 小 、 图 片 所 对 应 的 超 链接 。 

@ 插入 图 片 时 ,如 果 被 插入 的 图 片 文件 不 在 站 点 (不 与 HTML 文档 处 于 相同 文件 夹 ) 
中 ,系统 会 询问 设计 者 是 否 把 图 片 文件 复制 到 站 点 中 。 此 时 ,应 该 同意 DW 把 外 部 图 片 复 
制 到 站 点 目录 下 ,以 免 在 网 页 中 使 用 绝对 路 径 。 

@ 插入 图 片 时 ,尽量 不 要 利用 DW 调整 图 片 的 大 小 。 因 为 DW 仅 能 调整 图 片 在 屏幕 上 
的 显示 大 小 ,实际 并 不 改变 图 片 的 大 小 。 如 果 在 DW 下 缩小 图 片 ,会 导致 在 用 户 访问 网 站 
时 为 看 一 幅 小 图 片 而 需要 传输 大 图 片 ,导致 信道 浪费 。 因 此 ,对 于 大 图 片 ,一 般 要 通过 专门 
的 图 像 处 理 软件 调整 其 大 小 。 
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3. 设置 网 页 属性 

1) 设置 网 页 的 背景 

选择 系统 菜单 [修改 】 并 页 面 属性 】, 系 统 将 弹出 【页 面 属性 ] 对 话 框 ,如 图 1-3 所 示 。 在 
【背景 颜色 了 或 【背景 图 片 ] 栏 目 中 可 选择 背景 的 颜色 ,或 者 设置 背景 图 片 。 


1-3 【网 页 属性 ] 对 话 框 


2) 设置 页 面 默认 样式 和 标题 编码 属性 

选择 系统 菜单 【修改 -并 页 面 属性 】, 弹 出 【页 面 属 性 对话 框 ,在 [外观 】 民 链接 】 民 标题 
编码 ] 等 选项 中 进行 必要 的 设置 。 

3) 设置 标题 

选择 系统 菜单 [修改 >【 页 页 属性 】, 弹 出 [页面 属 性 ] 对 话 框 , 在 其 中 [标题 ] 栏 目 中 可 输 
入 网 页 的 标题 。 

4. 插入 超 链 接 

1) 插入 普通 “ 超 链接 ” 

选择 要 建立 超 链接 的 图 片 或 文字 ,然后 使 用 菜单 【插入 】->【 超 链接 】, 打 开创 建 超 链接 的 
对 话 框 ,如 图 1-4 所 示 。 

可 直接 在 【链接 】 文 本 框 中 输入 要 链接 的 
文件 名 称 ,也 可 以 单 击 其 右 侧 的 文件 夹 图 标 ， 
然后 选中 要 链接 的 文件 或 图 片 。 

2) 链接 为 Email 地 址 Ee 

选择 要 建立 超 链接 的 图 片 和 文字 ,然后 
使 用 菜单 [插入 】>【Email 链接 】, 然 后 在 对 话 
杠 [ 文 本】 文本 框 中 填写 可 建立 链接 的 文字 ， 
然后 在 [Email 中 填 和 Email 地 址 即 可 。 图 1-4 【起 链接 对话 杠 

3) 建立 热点 链接 

对 于 一 幅 图 片 ,可 以 针对 图 片上 的 特定 位 置 创建 热点 链接 。 例 如 ,针对 一 幅 中 国 地 图 ， 
可 以 分 别 对 北京 天 津 上 海 等 城市 建立 超 链 接 。 

要 建立 热点 链接 ,需要 先 选择 图 片 ,就 会 在 属性 了 面板 中 出 现 【地 图 选项 组 。 如 果 从 中 
选择 某 个 地 图 按钮 ,然后 就 能 在 图 片上 拖 动 鼠标 绘制 热点 区 域 , 并 在 【属性 了 面板 中 为 此 热点 
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输入 链接 地 址 ,建立 起 针对 热点 区 域 的 超 链接 。 

5. 保存 与 预览 

1) 保存 

网 页 设计 完毕 ,选择 菜单 [文件 ]->【 保 存 】, 系统 将 打开 文件 管理 窗口 ,命名 后 就 可 以 把 
网 页 保存 到 站 点 文件 夹 中 。 

2) 预览 网 页 设计 效果 

文件 保存 完毕 ,使 用 菜单 [文件 ]->【 在 浏览 器 中 预览 ]>IExplorer, 就 可 在 浏览 器 中 预 
览 网 页 的 设计 效果 ,也 可 以 直接 以 快捷 键 F12 进行 预览 。 


1.2.3 表格 的 使 用 


1. 表格 用 途 

在 网 页 设计 中 ,表格 具有 非常 重要 的 作用 ,表格 可 以 用 于 展示 信息 、 实 施 页 面 布局 ; 另 
外 ,表格 还 可 以 嵌 套 ,可 以 便利 地 设置 边框 背景 .宽度 等 。 因 此 表格 是 网 页 设计 中 实现 定 
位 ,组 织 信息 展示 的 重要 工具 。 

2. 表格 插入 

如 果 需 要 创建 表格 ,可 以 利用 菜单 [插入 】>【 表 格 ] 在 对 话 框 中 设置 表格 的 行 数 和 列 数 。 
就 可 直接 插入 所 需 行列 数 的 表格 。 

3. 表格 操作 

在 屏幕 上 插入 表格 后 ,可 以 利用 鼠标 拖 动 的 方式 移动 表格 线 , 改 变 单元 格 的 大 小 。 

在 向 单元 格 中 输入 内 容 时 ,DW 也 会 根据 单元 格 中 的 内 容量 自动 调节 单元 格 的 宽度 和 
高 度 。 

另外 ,还 可 以 在 选 定单 元 格 后 右 击 , 然 后 在 弹出 的 快捷 菜单 中 选择 【表格 】， 进 行 表格 的 
拆 分 、 合 并, 插入、 删除 等 常规 操作 。 

4. 设 定 表格 属性 

选 定 表 格 后 ,DW 底部 的 [属性] 面板 自动 切换 为 表格 的 [属性 ] 面 板 , 利 用 此 面板 可 以 方 
便 地 改变 表格 的 属性 ,如 图 1-5 所 示 。 

1) 表格 或 单元 格 的 背景 

选 定 表格 或 单元 格 后 ,在 【属性 了 面板 中 可 通过 【背景 ] 为 网 页 设置 背景 图 片 ,通过 【背景 
颜色 】 设 置 网 页 背景 的 颜色 。 

2) 表格 边框 

选 定 表格 或 单元 格 后 ,在 [属性 面板 中 利用 [边框 项 可 设置 边框 宽度 。 如 果 表 格 边 框 
宽度 为 0, 则 不 显示 边框 ,表格 变 成 无 线 表格 。 

3) 边框 颜色 

选 定 表格 或 单元 格 后 ,在 [属性 了 面板 中 利用 [边框 ] 项 可 设置 边框 的 颜色 。 

注意 : 利用 主 工作 区 底部 的 标记 <table 之 <tr>> 或 <td>> ,可 以 方便 地 选 定 表 格 、 表 格 
中 的 一 行 ,或 者 一 个 单元 格 。 

如 果 DW 窗口 中 的 [属性 了 面板 很 窄 ,可 单 击 此 面板 右上 角 的 按钮 ,展开 面板 ; 如 果 【 属 
性 面板 不 存在 , 则 可 通过 菜单 [窗口 >【 属 性 打开 [ 属 性 面板。 
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图 1-5 选择 并 设置 表格 属性 


1.2.4 插入 特殊 组 件 


1. 插入 特殊 图 片 

1) 插入 交替 图 片 

所 谓 插入 交替 图 片 ,就 是 指 在 同一 位 置 插入 两 幅 不 同 的 图 片 。 当 鼠标 停留 在 其 他 位 置 
时 ,默认 显示 一 幅 图 片 ; 当 鼠 标 停留 在 该 位 置 时 ,系统 将 显示 另外 一 幅 图 片 。 实 现 此 功能 的 
方法 如 下 。 

(1) 选择 菜单 [插入 】>【 图 像 对 象 】。 

(2) 选择 [鼠标 经 过 图 片 〗), 此 时 DW 弹出 对 话 框 ,要 求 开 发 者 设置 原始 图 片 和 交替 图 片 
的 名 称 。 

(3) 当 用 户 正确 地 提交 了 两 个 文件 名 后 , 单 击 【确定 按钮 ,确认 设置 。 

2) 插入 图 像 占 位 符 

在 以 DW 设计 网 页 时 ,可 插入 图 像 占 位 符 ,帮助 开发 者 确定 待 插入 对 象 的 位 置 。 插 入 
图 像 占 位 符 的 步骤 如 下 。 

(1) 选择 菜单 [插入 】>【 图 像 对 象 】 

(2) 选择 [图 像 占 位 符 】, 系统 将 弹出 对 话 框 ,要 求 设置 “名 称 ”、 占 位 符 的 高 度 和 宽度 。 

(3) 用 户 需 正确 回答 有 关 栏 目 后 , 单 击 【确定 ] 按 钮 。 

2. 插入 Flash 按钮 /文本 

1) 插入 Flash 按钮 

选择 系统 菜单 [插入 】>【 媒 体 】>【Flash 按钮 】, 系统 将 弹出 对 话 框 ,可 在 对 话 框 中 选用 
不 同形 式 的 按钮 ,然后 填写 显示 在 按钮 上 的 说 明文 字 , 以 及 按钮 所 对 应 的 链接 。 

2) 插入 Flash 文 本 

选择 系统 菜单 [插入 】>【 媒 体 】>【Flash 文本 】, 系统 将 弹出 对 话 框 ,可 在 对 话 框 中 输入 
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文字 ,并 设置 文字 的 特殊 效果 。 

3. 插入 书签 

如 果 必 要 ,可 以 选择 系统 菜单 [插入 】>【 命 名 锚 记 】 ,在 对 话 框 中 输入 “ 锚 记 名 称 ”, 在 网 
页 中 建立 书签 标记 。 

利用 书签 标记 ,可 以 建立 针对 网 页 内 部 特定 位 置 (书签 位 置 ) 的 超 链接 。 

4. 插入 水 平 线 

选择 菜单 [插入 >[HTML】->【 水 平 线 】, 可 在 网 页 中 插入 一 条 水 平 线 。 


1.2.5 设置 网 页 动画 效果 


1. 制作 滚动 字幕 

1) 水 平 滚动 字幕 

如 果 需 要 在 页 面 上 插 和 人 水 平 滚动 的 文字 或 图 片 ,可 以 先 选 定 需要 滚动 的 文字 和 图 片 , 然 
后 切换 到 DW 的 【代码 视图 下 ,会 发 现 文字 或 图 片 仍 处 于 选 定 状 态 。 此 时 ,只 需要 在 选 定 
的 代码 两 端 分 别 输入 "<marquee 二 >” 和"“* 王 /marquee 二 ”。 

二 marquee 之 和 过 /marquee 之 是 一 对 HTML 标记 ,其 功能 为 实现 文字 或 图 像 的 滚动 
效果 。 

2) 垂直 滚动 字幕 

如 果 需 要 在 页 面 上 插入 垂直 滚动 的 文字 或 图 片 , 可 以 先 选 定 需要 垂直 滚动 的 文字 和 图 
片 , 然 后 切换 到 【代码 了 方式 下 ,此 时 会 发 现 文字 或 图 片 仍 处 于 选 定 状态 ,只 需要 在 选 定 的 代 
码 两 端 分 别 输入 “<marquee direction 二 up width 王 宽度 height 王 高 度 之 ”和 "二 /marquee 之 ”, 预 
览 网 页 效果 时 就 会 发 现 选 定 的 内 容 会 在 一 个 矩形 区 域内 自 下 而 上 地 滚动 。 

此 处 ,“direction 二 up” 表 示 深 动 方向 , 子 属性 width 指定 滚动 窗口 的 宽度 ,height 指定 
滚动 窗口 的 高 度 。 

2. 直接 插入 视频 资料 

1) 插入 其 他 媒体 插件 

插入 到 网 页 中 的 视频 材料 不 仅 要 美观 ,而 且 要 能 为 大 多 数 的 浏览 器 所 识别 。 另 外 ,诸如 
Java Applet 等 也 是 经 常 插入 的 插件 之 一 。 插 入 媒体 插件 的 常用 方法 如 下 。 

(1) 选择 菜单 [插入 】>【 媒 体 】。 

(2) 然后 选择 一 种 组 件 。 

2) 插入 Flash 文件 

选择 菜单 [插入 】->【 媒 体 】->【Flash 组 件 】, 然 后 选择 一 个 Flash 产品 ,DW 系统 就 会 把 
此 产品 插 到 当前 光标 之 处 。 此 时 ,人 们 可 以 像 处 理 图片 一 样 修改 此 Flash 产品 的 属性 。 

如 果 浏 览 器 支持 Flash 产品 播放 ,那么 在 预览 网 页 效果 时 就 能 看 到 Flash 产品 的 播放 
效果 了 。 

3. 行为 动画 的 设计 

1) 行为 动画 的 作用 

在 以 DW 设计 网 页 时 ,可 以 为 其 中 的 某 个 对 象 的 事件 添加 某 种 动作 , 即 添加 行为 。 常 
见 的 操作 有 以 下 3 种 。 

(1) 为 body 的 load 事件 添加 弹出 窗口 效果 ,或 者 为 某 个 按钮 的 click 事件 添加 关闭 当 
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前 窗口 的 行为 。 

(2) 插入 层 对 象 ,然后 在 层 对 象 中 插入 图 像 ; 通过 改变 层 对 象 在 不 同时 刻 的 位 置 ,建立 
小 图 片 在 页 面 上 跑 动 的 动画 效果 。 这 一 技术 在 设计 广告 页 面 时 被 广泛 地 采用 。 

(3) 在 时 间 轴 的 特定 位 置 插入 行为 ,使 系统 运行 到 此 处 时 可 以 产生 特定 的 效果 。 

2) 设计 行为 动画 的 基本 操作 方法 

(1) 利用 菜单 [窗口 >【 行 为 打开 [ 行 为 ] 面 板 ,为 创建 行为 动画 创建 条 件 。 

(2) 选 定 某 个 对 象 , 利 用 [行为 ] 面 板 的 [十] 按钮 为 该 对 象 添加 特定 的 行为 。 

3) 为 页 面 对 象 添加 弹出 窗口 的 动作 

(1) 选 定 要 添加 弹出 窗口 的 对 象 。 可 以 选择 网 页 中 的 图 片 .按钮 等 对 象 。 

(2) 单 击 【行为 3 面板 左上 角 的 [十 按钮 ,表示 添加 行为 动画 。 系 统 将 弹出 快捷 菜单 , 选 
择 其 中 的 [弹出 信息 】, 系 统 将 弹出 对 话 框 ,可 以 在 [消息 ] 框 中 填写 要 输出 的 信息 。 

在 这 个 过 程 中 ,可 以 设置 触发 此 动作 的 事件 。 系 统 默认 以 onLoad 事件 触发 弹出 窗 
口 的 动作 ,开发 者 可 以 通过 onLoad 右 侧 的 按钮 改变 触发 此 动作 的 事件 (如 选择 Click 
事件 ) 。 

4) 设置 文本 

与 前 面 的 方法 相同 ,在 选 定 对 象 后 , 单 击 【 行 为 3 面板 左上 角 的 【5 十] 按钮 ,在 快捷 菜单 中 
选择 [设置 文本 】, 系 统 将 弹出 对 话 框 。 此 时 可 以 在 这 个 对 话 框 中 输入 要 弹出 的 文字 ,并 设置 
触发 此 动作 的 事件 。 

5) 弹出 新 的 浏览 窗口 

在 选 定 对 象 后 , 单 击 [行为 3 面板 左上 角 的 【十 按钮 ,在 快捷 菜单 中 选择 [打开 浏览 器 窗 
口 〗, 系 统 将 弹出 对 话 框 。 此 时 可 以 在 URL 框 输入 要 在 此 窗口 中 浏览 的 网 页 。 当 然 , 还 可 
以 利用 此 对 话 框 调整 新 窗口 的 属性 。 

6) 同时 调 入 其 他 对 象 

同 理 , 也 可 以 利用 此 方法 为 选 定 对 象 添加 【播放 声音 了 等 行为 动画 。 

系统 默认 在 onLoad 事件 发 生 时 触发 此 动作 的 事件 ,开发 者 可 通过 onLoad 右 侧 的 按钮 
改变 触发 此 动作 的 事件 。 

4. 制作 在 屏幕 上 跑 动 的 小 图 片 

1) 插入 层 对 象 

利用 DW 的 菜单 [插入 】>【 布 局 对 象 ]>【 层 】, 将 在 DW 的 网 页 中 插入 一 个 层 对 象 
(DIV 对 象 ), 人 们 可 以 把 图 片 或 文字 插入 到 这 个 层 对 象 中 。 此 时 , 层 及 其 内 部 的 图 片 就 构 
成 了 一 个 可 以 随意 改变 位 置 的 运动 对 象 。 

开发 者 可 把 此 对 象 调 整 到 适当 的 位 置 ,作为 运动 的 起 点 位 置 。 

2) 打开 [时 间 轴 面板 

利用 菜单 [窗口 >【 时 间 轴 】 ,系统 将 打开 [时 间 轴 面板 。 

3) 将 层 对 象 与 时 间 轴 联系 起 来 

选中 层 对 象 ,然后 将 它 拖 到 【时 间 轴 了 面板 的 第 一 帧 上 。 此 时 层 作 为 一 个 对 象 被 放 到 时 
间 轴 上 ,而 且 默认 长 度 为 15 帧 。 

4) 调整 运行 时 间 

以 鼠标 拖 动 时 间 线 上 的 层 对 象 的 终点 (默认 在 15 帧 ) ,延长 时 间 线 终点 。 
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5) 调整 运行 轨迹 

右 击 时 间 轴 上 的 某 一 帧 ,在 弹出 的 菜单 中 选择 [添加 关键 帧 】, 系统 将 在 时 间 轴 上 为 层 对 
象 添 加 一 个 关键 帧 。 然 后 以 鼠标 拖 弄 [设计 了 视图 中 的 层 对 象 ,改变 其 存放 位 置 。 此 时 会 发 
现 层 对 象 的 移动 将 会 留 下 一 道 运动 轨迹 。 

重复 此 步骤 ,可 添加 多 个 关键 帧 ,并 针对 每 个 关键 帧 改变 层 对 象 的 存放 位 置 。 

6) 设置 动画 为 自动 播放 和 循环 播放 

把 时 间 轴 中 上 部 的 “自动 播放 ”和 “循环 " 复 选 框 选中 ,使 动画 的 播放 成 为 自动 播放 和 循 
环 播放 模式 。 

7) 在 浏览 器 中 预览 效果 

利用 菜单 文件】 并 在 浏览 器 中 预览 〗 观 察 最 终 效果 。 


1.2.6 认识 网 页 源 代 码 


1. 网 页 文件 基本 结构 


1) 网 页 的 基本 结构 
在 DW 下 ,新 建 一 个 空白 的 HTML 文档 。 然 后 切换 到 [代码 方式 下 ,观察 其 源 文件 ， 


能 够 看 到 如 图 1-6 所 示 的 基本 结构 。 


<htnl> 


加 <meta http-equiv="Content-Type" content="text/html; charset=gb2312"> 
中 ctitle? 新 建 网 贝 1</title> 


<body> 

EB Ctable border="1" width="64%" id="tablel"> 
加 《trz>tdy CJtaetd> Cfta> ftr> 
Ctr>Ctd> CJtdyetd> /ta ftr> 


Ee </htnl> 


图 1-6 网 页 的 基本 结构 


2) 网 页 源 文件 的 基本 组 成 

“< 过 html 之 </html 之 ”是 网 页 文件 标记 。 每 个 页 面 以 反 html 之 开头 ,以 过 /html > 
结束 。 

“到 head>> 志 /head> "是 网 页 头 标 记 , 可 在 此 标记 中 间 放 置 网 页 的 配置 信息 ,例如 网 页 
使 用 的 语言 编码 .网 页 的 标题 等 信息 。 处 于 网 页 头 标记 中 间 的 内 容 在 网 页 浏览 时 不 会 呈现 
出 来 。 

“<meta http-equiv= "Content-Type" content= "text/html"; charset= "gb2312">” 
中 的 charset 项 说 明 网 页 使 用 的 语言 ,其 中 gb2312 代表 简体 中 文 , BIG5 代表 繁体 中 文 ， 
GBK 代表 国际 大 字符 集 编码 ,utf-8 是 国际 通用 编码 。 

在 二 head 记 过/head 记 中 间 可 以 通过 过 title 之 过 /title 设 置 网 页 标题 。 

“过 body 之 过 /body 之 ”用 于 标记 网 页 主体 ,用 于 存放 网 页 中 需要 呈现 的 全 部 内 容 。 在 
<<body>></body> 之 间 可 以 有 文字 ,表格 .图片 . 超 链 接 。 

网 页 中 的 文字 通常 直接 被 存放 在 HTML 文档 中 ,可 以 直接 书写 。 文 字 格式 由 <<font> 
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去 /font> 控 制 , 或 者 由 预定 义 的 样式 进行 控制 。 

位 于 <<body> 中 的 “<table 之 <</table 之 ”表示 一 个 表格 ,其 中 “<tr 之 <</tr 之 ”表示 表 
格 中 的 一 行 ,而 “过 td 二 过 /td 这 ”表示 一 个 单元 格 。 

2. 普通 静态 网 页 文件 示例 

1) 网 页 界面 与 对 应 的 HTML 代码 示例 

为 提高 教学 质量 ,笔者 需要 为 多 门 课程 的 教学 建立 网 络 学 习 支 持平 台 。 经 初步 规划 , 需 
要 建设 如 图 1-7 所 示 的 网 页 。 为 实现 网 页 设计 ,预先 准备 了 Logo 标志 ,如 图 1-8 所 示 。 


导管 理 信息 系统 - 于 crosoft Internet Explorer 
文件 四 编辑 至) 查看 W) 收藏 人 工具 C) 帮助 人 D 


Ba 昌国 国人 的 Pa 夫 wmx @ 合 - 妨 回 - 品 
地 址 国 央 GMttt2Vindex htn 


欢迎 您 的 光临 


图 1-7 网 络 课程 主页 面 


兹 六 纯 郑 大 学 
精品 很 程 建 级 


图 1-8 网 络 课程 站 点 的 Logo 标志 


在 DW 下 ,打开 图 1-7 所 示 页 面 对 应 的 HTML 文件 ,切换 到 【代码 方式 下 ,看 到 的 
HTML 文件 如 图 1-9 所 示 。 

2) 对 HTML 代码 的 解释 

HTML 语言 规定 。 每 个 格式 控制 命令 由 单 书 名 号 括 起 来 的 命令 开始 ,用 单 书 名 号 括 起 
的 “/ 命 令 " 表 示 命 令 的 结束 。 例 如 过 html 志 表示 HTML 网 页 开始 ,而 <</html 之 则 表示 网 
页 结束 。 

去 head> 志 /head> 之 间 的 部 分 是 对 网 页 整体 性 质 的 描述 ,主要 有 网 页 的 标题 (例如 
title 之 间 的 “管理 信息 系统 ”) ,网 页 所 使 用 的 语言 及 字符 集 (charset 二 gb2312 和 content 王 


"zh-cn" )。 
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01 <html >< head > 

02 <meta http— equiv = "Content - Language" content = " zh- cn"> 

03 <meta http— equiv = "Content - Type" content = "text/html; charset = gb2312"> 
04 <title> 管 理 信息 系统 </title></head> 


06 <body><center> 

07 <table border = "1" width= "790" id= "tablel"> 

08 <tr><td colspan= "2">< img src = "topx. jpg" width= "780" height = "106"></td> 

09 </tr><tr><td width= "16%" background = "bk002. jpg"> <p style= "line— height: 150% "> 


10 <a target = "xitimain" href = "glxx. htm"> 管 理 信息 系统 </a><br> 

11 <a target = "xitimain”" href = "mmedia. htm"> 多 媒体 与 网 页 制作 </a><br> 

2 <a target = "xitimain" href = "dtswgpage. htm"> 动 态 网 站 建设 </a></td> 

13 <td width= "77%" bgcolor = "#99FFCC"> 

14 < iframe name = "xitimain" marginwidth= "1" marginheight = "1" height = "300" width = 
15 | "620" src = "mxl. jpg"> 浏 览 器 不 支持 嵌入 式 框 架 。</iframe> 

16 </tr> <tr><tdcolspan= "2"> 

17 <palign= "center">< font face = "宋体 " color = "#FF0000" size = 4><marquee > 欢迎 您 的 
18 | 光临 </marquee ></font ></p></td> 

2 </tr></table></Center > 

20 </body ></html > 


1-9 网 络 课程 网 页 (图 1-7) 对 应 的 HTML 源 代码 


忆 body> 命 令 表示 网 页 主体 部 分 ,网 页 的 内 容 都 应 该 存放 在 <<body 之 和 /body> 
之 间 x 

之 center> 表 示 居 中 ,其 含义 是 放 在 <<center> 与 </center 一 之 间 的 内 容 要 居中 显示 。 

<<table> 与 二 /table> 之 间 的 内 容 表示 一 个 表格 。 本 例 中 ,表格 主要 用 于 精确 定位 , 确 
定 网 页 对 象 的 位 置 。 表 格 中 间 的 二 td 二 过 /td 二 表示 一 个 单元 格 ,二 tr 达 /tr 二 表示 一 行 
表格 。 

语句 “之 img src 二 topx. jpg width 二 "780”height 二 "106" 放 ”表示 插入 一 个 宽度 为 
780 像素 、 高 度 为 106 像素 的 图 片 ,img 表示 当前 对 象 为 图 片 ,src 表示 后 面 是 图 片 文件 名 ; 
topx. jpg 则 是 一 个 图 片 文件 名 , 即 顶部 的 “北京 师范 大 学 精品 课程 建设 ”图片 。 这 个 语句 被 
放 在 <<td>> 坟 /td> 之 间 , 说 明 该 图 形 被 放置 在 此 单元 格 中 。 

过 background 二 bk002. jpg> 表 示 利 用 图 片 文件 bk002. jpg 作为 背景 ,由 于 本 语句 被 放 
在 二 td> 中 ,说 明 该 单元 格 的 背景 是 图 片 bk002. jpg。 

语句 “过 a target 二 "xitimain"” href 二 "mmedia. htm" 之 多 媒体 与 网 页 制作 志 /a 之 ”表示 
要 插入 一 个 超 链接 ,该 链接 的 标记 是 文字 “多 媒体 与 网 页 制作 ”, 当 单 击 该 链接 标记 时 ,将 跳 
转 到 新 网 页 “mmedia. htm”, 而 且 新 网 页 的 内 容 显示 在 嵌入 式 框架 xitimain 中 。 

语句 “过 iframe name 王 "xitimain”marginwidth 一 "1”marginheight 王 "1”height 一 
"300" width 王 "620" src 一 "mxl.jpg" 过 浏览 器 不 支持 能 入 式 框架 。 志 /iframe> ”表示 搬入 
一 个 嵌入 式 框架 ,框架 的 名 字 为 xitimain ,框架 的 宽 为 620 像素 ,高 为 300 像素 ,框架 区 域 中 
默认 显示 图 形 文件 mxl.jpg。 由 于 嵌入 式 框架 是 页 面 上 相对 独立 的 区 域 ,可 以 根据 用 户 需 
求 在 这 个 区 域 中 显示 不 同文 件 的 内 容 。 例 如 ,把 “多 媒体 与 网 页 制作 ”的 对 应 网 页 mmedia. 
htm 的 内 容 显示 在 这 个 框架 xitimain 中 。 

语句 “一 font face 王 "宋体 "color 王 "#fft0000" size 二 "4" 这 过 /font 记 ”表示 设置 文字 格 
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式 为 “宋体 ,4 号 字 , 红 色 ”。 二 font 是 负责 设置 文字 格式 的 命令 ,其 子 项 face 说 明 字体 ， 
size 则 说 明 字号 ,color 表示 颜色 。 
另外 , 子 命令 项 二 br 二 表示 换行 。<p 二 表示 段落 开始 , <</p 二 表示 段落 结束 。 
二 marquee> 妈 /marquee 之 表示 采用 滚动 字幕 ,使 文字 “欢迎 您 的 光临 !" 滚 动 起 来 。 


(3 网 页 布局 


在 网 页 设计 中 ,网 页 风格 和 网 页 布局 是 反映 网 页 设计 质量 的 重要 因素 。 其 中 ,网 页 设计 
风格 反映 了 网 页 的 基调 ,例如 描述 环保 的 页 面 通常 基于 浅 绿色 调 , 而 面向 党 团 活动 的 网 页 多 
以 红色 作为 主 色调 ; 网 页 的 布局 则 指 网 页 页 面 的 分 布 、 页 面 结构 。 

在 网 页 设计 技术 中 ,常见 的 网 页 布局 方式 有 3 种 , 即 表格 布局 ,CSS 十 DIV 布局 和 框架 
布局 ,而 网 页 风格 和 文字 格式 则 常常 基于 样式 。 


1.3,1 样式 与 CSS 文 件 


样式 是 网 页 设计 中 非常 重要 的 一 个 概念 。 其 代码 可 以 直接 存储 在 HTML 文件 中 ,也 
可 以 作为 独立 的 CSS 文件 存在 。 存 储 在 HTML 文件 中 的 样式 代码 一 般 被 二 style 之 和 
去 /style> 标 记 标 识 。 

1. 使 用 样式 的 原因 

1) 样式 定义 的 必要 性 

在 网 页 设计 中 ,通常 不 直接 设计 每 段 字符 的 格式 (字形 .字号 和 字体 ) 。 因 为 一 个 网 站 中 
涉及 的 页 面 很 多 ,而 且 每 个 页 面 内 都 包含 着 大 量 的 信息 。 如 果 逐 段 进 行 字体 .字形 和 字号 的 
设置 ,其 工作 量 很 大 。 更 重要 的 是 ,在 网 站 信息 量 很 大 的 情况 下 ,这 种 逐 段 进行 文本 格式 设 
置 的 方式 容易 导致 各 个 页 面 的 文本 格式 不 一 致 ,影响 网 站 的 整体 风格 。 在 这 种 模式 下 ,如果 
需要 同时 改变 网 站 中 所 有 页 面 的 文字 风格 ,其 工作 量 是 相当 巨大 的 。 因 此 ,在 网 站 开发 中 提 
出 了 样式 和 样式 文件 的 概念 。 

2) 样式 的 概念 

在 网 页 设计 中 ,为 提高 开发 效率 ,人 们 通常 把 若干 个 格式 符 组 织 在 一 起 作为 整体 使 用 ， 
这 个 整体 通常 被 赋予 一 个 独立 的 名 称 , 这 就 是 样式 。 所 谓 样 式 ,就 是 组 织 在 一 起 的 一 组 格 
式 , 这 组 格式 可 以 通过 样式 名 称 直接 作用 于 文字 、 表 格 等 页 面 对 象 ,从 而 快速 地 设置 它们 的 
显示 格式 。 

因此 , 当 样 式 被 定义 后 ,对 某 段 文字 的 格式 设置 就 不 必 按 照 字体 、 字 形 、 字 号 分 别 进 
行 了 ,而 是 直接 选用 某 个 样式 。 当 然 , 如 果 对 当前 文本 显示 格式 不 满意 ,只 要 修改 样式 内 
部 的 格式 ,就 可 以 引发 所 有 使 用 此 样式 的 文本 格式 同时 发 生变 化 ,进而 实现 快速 更 新 网 
页 显示 风格 的 目的 。 随 着 样式 概念 的 普及 ,样式 设置 已 经 不 再 局 限于 对 文本 显示 格式 的 
设置 ,而 是 逐步 普及 到 规范 超 链接 格式 、 定 义 DIV 对 象 的 大 小 、 位 置 和 外 观 等 ,涉及 网 页 
显示 的 诸多 方面 。 目 前 ,利用 样式 已 经 可 以 为 某 些 特殊 操作 、 网 页 背景 等 设置 统一 的 标 
准 。 例 如 ,为 超 链接 的 悬 停 实现 特殊 的 效果 ,或 者 设 定 特殊 的 标题 .文字 效果 、 图 片 效 
果 等 。 
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3) CSS 样式 文件 

定义 在 一 个 网 页 内 部 的 样式 只 能 作用 于 这 个 网 页 内 部 ,其 他 网 页 难以 使 用 这 些 样 式 。 
为 了 使 一 个 网 站 中 的 多 个 网 页 都 能 使 用 同样 的 样式 ,就 需要 把 这 些 样 式 独立 出 来 ,形成 一 个 
单独 的 文档 ,这 个 文档 就 称 为 样式 文件 ,也 被 人 们 称 为 CSS 样式 表 。 

当 服 务 于 一 个 网 站 全 体 页 面 的 CSS 样式 文件 建立 后 ,所 有 网 页 都 可 引用 此 样式 文件 ， 
并 使 用 此 文档 中 定义 好 的 样式 。 对 CSS 文档 中 的 一 次 修改 将 会 自动 地 影响 与 此 样式 相关 
的 所 有 页 面 。 因 此 ,可 以 说 样式 与 样式 文件 对 于 加 速 设置 网 页 内 部 对 象 的 格式 ,统一 网 站 中 
各 个 网 页 的 风格 、 并 快速 地 统一 修改 所 有 网 页 的 现实 形式 ,都 具有 重要 的 意义 。 

2. 样式 的 类 型 

一 个 样式 表 由 若干 样式 规则 构成 ,样式 规则 就 是 关于 网 页 元 素 的 格式 的 定义 ,可 以 包括 
元 素 的 显示 方式 和 元 素 在 页 面 中 的 位 置 等 信息 。 关 于 样式 的 定义 , 既 可 以 针对 HTML 标 
记 ( 如 过 body>`<p 过 等 ) ,也 可 以 由 开发 者 新 建 独立 的 样式 。 

1) 标记 选择 符 

任何 一 个 HTML 标记 都 可 以 成 为 样式 的 标记 选择 符 , 从 而 为 这 个 标记 设 定 样式 。 最 
常见 的 形式 是 为 标记 忆 body 之 和 过 p 之 设置 样式 。 

为 HTML 标记 直接 设置 样式 的 方法 为 : 先 说 明 HTML 标记 ,然后 在 “()” 中 说 明 这 个 
标记 的 样式 。 例 如 “body{fontfamily: 宋 体 ;font-size:30px;} "指定 了 网 页 主体 的 默认 字体 
和 文字 的 大 小 ; 而 *p{font-family: 宋 体 ;font-size:30px;color: # ff00ff;)}” 则 指明 了 行 标记 p 
所 控制 的 文字 的 显示 格式 。 

2) 类 选择 符 

在 样式 定义 中 ,允许 为 一 个 HTML 标记 定义 多 个 样式 。 为 实现 这 一 目的 ,可 以 先 为 
HTML 标记 定义 不 同 的 类 ,然后 再 针对 这 个 类 定义 样式 。 

为 HTML 标记 定义 类 及 其 格式 的 方法 为 : HTML 标记 . 类 名 { 格 式 语句 ;}。 例 如 ， 
“p. one{font-family: 黑 体 ;font-size:20px;)” 和 “p. two(font-family: 宋 体 ;font-size:30px;)” 
分 别 为 段落 标记 *“p” 定 义 了 2 种 不 同 的 类 ,从 而 可 在 使 用 二 p 二 标记 时 以 <p class 二 one 二 张 
小 三 过 /p 二 来 表示 对 文字 “ 张 小 三 ”使 用 第 “one” 类 样式 。 

在 网 站 开发 中 ,人 们 更 习惯 使 用 与 HTML 标记 无 关 的 类 , 即 定义 一 个 不 限制 HTML 
标记 的 类 ,这 种 类 可 以 使 用 在 任何 HTML 标记 中 ,使 用 保留 字 class 二 “类 名 ”来 限定 该 
HTML 标记 所 选用 的 样式 。 

例如 ,“. bt{font-family: 黑 体 ;font-size:20px;)” 就 定义 了 一 个 与 标记 无 关 的 独立 类 bt， 
而 语句 “< 之 p class 二 bt 二 张 小 三 之 /p 这 ” 则 表示 文字 “ 张 小 三 ”使 用 类 样式 “bt”。 

3) 伪 类 

伪 类 是 CSS 中 非常 特殊 的 类 ,可 以 自动 地 被 支持 CSS 的 浏览 器 识别 。 伪 类 主要 面向 超 链 
接 <<a> ,可 以 为 <<a> 定 义 4 种 方式 下 的 外 观 , 即 依次 为 a: link{)、a:visited{}、a: hover{}、 
asactive{} 定 义 样式 ,分 别 表示 "链接 .已 访问 过 的 链接 .鼠标 停 在 上 方 时 .点 下 鼠标 时 ”的 样 
式 。 对 于 上 述 4 种 样式 ,必须 按照 以 上 顺序 书写 ,否则 其 最 终 效果 可 能 与 预想 结果 不 同 。 

除了 上 述 3 种 类 型 外 ,还 有 关联 选择 符 ,并列 选择 符 等 多 种 方式 的 样式 类 型 。 

3. 样式 的 存储 方式 

在 网 页 设计 中 ,样式 可 以 以 两 种 方式 存在 : 其 一 是 内 联 式 , 其 二 是 级 联 式 。 其 中 级 联 式 
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样式 又 可 以 分 为 内 嵌 式 和 链接 式 两 种 形式 。 内 联 式 和 内 赃 式 都 以 二 style 二 为 标记 关键 字 ， 
嵌入 到 网 页 内 部 ,而 链接 式 则 以 独立 CSS 样式 文件 的 方式 存储 样式 的 定义 信息 。 

1) 网 页 的 内 联 式 样式 

所 谓 内 联 式样 式 ,也 叫 行内 样式 ,是 指 直 接 在 元 素 内 部 指定 元 素 的 样式 。 例 如 ， 
“<p style= "fontfamily: 宋 体 ;fontrsize:30px" 过 ”就 直接 在 元 素 p 内 部 定义 了 p 对 当前 行 
文字 的 格式 定义 ,形成 了 一 个 固定 的 样式 “font-family: 宋 体 ;font-size:30px”。 

2) 网 页 的 内 嵌 式 样式 

样式 规则 可 以 被 “一 style>> 志 /style> ?语句 括 起 来 ,集中 化 地 艇 在 网 页 内 部 。 在 这 种 模式 
下 ,每 个 样式 都 可 以 包含 若干 格式 语句 ,这 些 格 式 语句 被 用 *(}” 包 起 来 ,如 图 1-10 所 示 。 


《style type="text/css"> 

fo 

,STYLE2 {color: #FF0000} 

,STYLE3 {font-size: 36px; font-fanily: "宋体 ";} 


/style> 


图 1-10 内 散 式 样式 的 结构 


在 图 1-10 中 定义 了 2 个 样式 ,其 一 为 STYLE2 ,定义 了 一 种 颜色 *#FF0000”, 即 红色 ; 
其 二 为 SYTLE3, 它 定义 了 一 种 字体 “宋体 ”, 而 且 规定 字 的 大 小 为 36px。 

对 于 已 经 成 功 定义 的 样式 ,可 以 在 设置 文本 格式 时 ,直接 通过 【属性 】 面 板 选 择 使 用 。 

3) CSS 样式 文件 

如 果 把 若干 个 样式 保存 在 一 个 独立 的 文件 中 ,这 个 文件 就 是 独立 的 CSS 样式 文件 。 
CSS 样式 文件 的 结构 如 图 1-11 所 示 。 


/村 CSS3 Docunent */ 

.Btl {color: #FF0000] 

.Txt {font-size: 36px，font-fanil7y: “宋体 ";} 

body, td, th { 
Color: #00FFFF; 

jt 

body { 
backeround-color: #99FFFF 
backeround-image’; url (mmm. jipg); 
margin-left: Opx; 
margin-right: Opx 


图 1-11 CSS 样 式 文件 的 结构 


在 CSS 文件 中 ,不 需要 专门 的 标志 符 过 style 记 过 /style 二 标记 样式 。 图 1-11 中 定义 了 5 
个 样式 : Btl ,Txt ,body,td 和 th。 其 中 对 body 的 边 距 ,背景 和 文字 颜色 分 两 次 进行 了 配置 。 

4. CSS 文件 设计 

1) 新 建 CSS 文 件 

在 DW 中 ,可 以 便利 地 创建 CSS 文件 ,其 基本 步骤 如 下 。 

首先 ,选择 系统 菜单 [文件 】->【 新 建 】, 在 【基本 页 中 选择 “CSS”, 然 后 单 击 【创建 3 按钮 
即 可 进入 到 CSS 文 档 编辑 状态 。 

其 次 ,利用 菜单 [窗口 >【CSS 样式 】 ,打开 [CSS 样式 了 面板 ,如 图 1-12 所 示 。 
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最 后 , 右 击 图 1-12 中 的 “Untitled-3” 标 记 , 选 择 “ 新 建 ”， 
则 打开 创建 新 的 样式 规则 的 对 话 框 。 可 以 选择 创建 新 的 
类 、 对 已 有 的 标记 设置 样式 ,为 超 链接 的 4 个 伪 类 设计 专用 
样式 。 

本 例 中 选择 “类 ”, 并 在 “名 称 ” 文 本 框 中 输入 文字 Ma， 
表示 要 创建 名 字 为 Ma 的 新 类 。 设置 完成 后 单 击 【确定 ] 按 
钮 ,DW 将 会 打开 如 图 1-13 所 示 的 规则 定义 对 话 框 。 

在 图 1-13 所 示 的 界面 上 ,可 以 直接 为 类 Ma 在 字体 ,大 
小 .样式 , 行 高 .颜色 ,边框 ,背景 等 方面 进行 格式 设置 。 图 1-12 创建 CSS 文 件 


Ma 的 CSS 规则 定义 


图 1-13 定义 Ma 的 样式 规则 


按照 这 种 方法 ,可 在 CSS 文件 中 陆续 定义 若干 个 样式 。 

2) CSS 文件 示例 

在 笔者 的 教学 服务 器 平台 中 ,所 有 的 网 页 都 使 用 了 同一 个 CSS 文件 ,其 内 容 如 图 1-14 所 示 。 

5. 在 网 页 中 使 用 CSS 文件 

1) 附加 CSS 样式 文件 

当 CSS 样式 文件 定义 完成 后 ,在 网 页 设计 时 就 可 以 使 用 CSS 样式 文件 了 。 其 过 程 为 如 
下 所 述 。 

首先 ,把 CSS 文件 复制 到 站 点 文件 夹 中 。 

其 次 ,利用 菜单 [文本 】->【CSS 样式 】, 在 弹出 的 子 菜单 中 选择 [附加 样式 表 】, 接 着 就 可 
以 选择 CSS 文件 了 。 

当 CSS 文件 被 附加 到 当前 网 页 后 ,在 网 页 的 代码 方式 下 就 会 增加 一 条 语句 : 


< 1ink href = "样式 文件 名 .css" rel = "stylesheet" type = "text/css" /> 


表示 指定 的 CSS 文件 已 经 被 当前 网 页 引用 。 此 时 定义 在 CSS 文件 中 的 HTML 标记 的 
样式 会 自动 生效 ,而 定义 为 类 的 样式 则 显示 在 【属性 了 面板 的 [样式 ] 列 表 框 中 ,可 供 开 发 者 随 
时 选用 。 

2) 借用 他 人 的 优秀 样式 

在 浏览 网 页 时 ,如 果 有 较 好 的 样式 ,在 不 造成 侵权 的 情况 下 ,可 以 把 这 些 样式 粘贴 到 自 
己 的 网 页 文件 中 。 其 具体 操作 过 程 如 下 。 
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body, td, th { 


1 
} 
.btd { 


} 
.bt3 { 


i 
f 


.bt2 1 


font-weight: bold; } 
.btl { 


font-weight: bold; } 


.text { 


text-decoration: none; ] 
.STEXT { 
ailink { 

text-decoration; underline; } 
aivisited { 


aihover { 


aiactivVe { 


text-decoration; underline; } 


font-fanily: 宋体 ; font-size: 14px; color: #0033CC; 
font-fanily: "宋体 " ;font-size: l6px; color: #000000; font-weight: bold; 
font-fanily: "宋体 " ,font-size: 18px; color: #8000ff, font-weight: bold; 
font-family: "华文 中 宋 " font-size: 24dpx; line-height: 28px; color: #cc00ff 
font-fanmily: "隶书 "; font-size: 32px; line-height: 36px; color: #800040; 
font-fanily: "宋体 "; font-size: ldpx; line-height: 17px 

text-indent: 92; line-height: 150%; text-align:; left; 

font-fanily: 宋体 ; font-size: 14px; color: #006699; margin: 0 } 

font-size: ldpx, line-height: 1l8px;, color: #0000FF,; 

font-size; ldpx; line-height; 1l8px; color; #0000FF, text-decoration; underline, 


font-size: ldpx; line-height: 1l8px; color: #FFO000; 


text-decoration; underline; background-color: #a0fOf0;} 


font-size: 1dpx; line-height: 18px; color: #FF0000; 


图 1-14 笔者 服务 器 平台 中 所 用 CSS 文件 的 内 容 


在 浏览 器 下 ,用 [查看 ->【 源 文件 ] 菜 单 命令 检查 优秀 网 页 的 源 代码 ,将 代码 中 过 style 二 和 
过/style 二 之 间 的 内 容 选 中 ,然后 利用 Ctrl 十 C 快捷 键 将 其 送 入 剪贴 板 。 

在 DW 中 ,进入 到 [代码 ] 视 图 ,找到 过 style 代 码 , 将 光标 放 在 过 style 志 标记 后 边 , 然 
后 使 用 Ctrl 十 V 快捷 键 将 样式 粘贴 到 自己 的 网 页 文件 中 。 


6. 具有 特色 的 样式 示例 


1) 设置 超 链接 的 特殊 属性 ( 见 图 1-15) 


2) 实现 文字 模糊 效果 ( 见 图 1-16) 


区 ys01. txt - 记事 本 
文件 EE) 编 轿 E) 格式 (0) 查看 ( 习 攻 助 (四 


198.5pt; line-height: 18px; 
9FF; text-decoration: underline; 


要 
azuisited { 
font-size: 10.5pt; line-height: 18px; 
color: #9999FF; text-decoration: underline; 
上 
azhover { 
font-size: 10.5pt; line-height: 18px; 
color: FMA0; text-decoration: underline; 
background-color: #80F080; 
器 
azactive { 
font-size: 19.5pt; line-height: 18px; 
color: MFF8000; Ktext-decoration: underline; 


图 1-15 超 链 接 的 特殊 属性 ( 伪 类 ) 


区 ys02. txt - 记事 本 


文件 (E) 编 回 (E) 格式 (0) 查看 ( 帮助 (E) 

|.Flane 《 font-fanily: 方正 舒 体 ; color: F8898; 
font-size: 36pt; text-align: center 
position: absolute; left: 19; top: 10; 
Filter:6low(Color=Red, Strength=18);} 


图 1-16 实现 文字 模糊 效果 的 样式 
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3) 实现 滚动 窗口 效果 ( 见 图 1-17) 


区 ys03. txt - 记事 本 
文件 (FE) 纺 纺 信 ) 格式 OO) 查看 帮助 (四 
.aaa《 position: absolute; left: 25; top: 199; width: 379; height: 88; 


Font-size:18pt; font-fanily: 宋体 ; font-weight: bold; 
line-height: 15%; ouerflou: auto; border-style: ridge; border-width: 3 } 


图 1-17 实现 窗口 效果 的 样式 


4) 实现 图 片 色调 翻转 效果 ( 见 图 1-18) 


区 ys04. txt - 记事 本 
| 文件 E) 编 入 人 E) 格式 ) 查看 (四 帮助 加 


-inuert { position: absolute; left: 15%; top: 50; 
Filter:invert; 》 


1-18 实现 图 片 翻转 效果 的 样式 
1.3.2 以 表格 实施 布局 


页 面 布局 是 网 页 设计 的 首要 任务 。 在 早期 的 网 页 设计 中 , 主要 通过 在 页 面 上 绘制 表格 
实现 页 面 布局 。 为 此 ,DW 专门 提供 了 布局 网 页 的 功能 。 

1. 进入 页 面 布局 模式 

在 网 页 设计 状态 下 , 单 击 图 1-1 中 “1” 处 标记 的 标签 ,把 当前 的 [常用 ] 面 板 更 改 为 [ 布 
局 了 面板 ,然后 单 击 【 布 局 按钮 ,进入 到 布局 模式 ,如 图 1-19 所 示 。 


OMacronedia Dreanweaver 8 - [Untitled-l (XHT... [El 
文件 亿 如 吉大 名 入 MD 人 kD 文本 全) 站 点 G) EE 


NA lo -|593x1l9v 1X/1 秒 


图 1-19 DW 的 布局 模式 

2. 绘制 布局 单元 格 

在 布局 模式 下 , 单 击 【绘制 布局 单元 格 ] 按 钮 后 ,鼠标 指针 变 成 “十 "字形 形状 ,此 时 可 直 
接 在 窗口 中 绘制 布局 单元 格 , 把 网 页 布局 为 若干 个 可 以 输入 数据 的 区 域 。 

注意 : 【绘制 布 局 单元 格 ] 按 钮 就 是 图 1-19 中 被 用 椭圆 圈 起 来 的 按钮 。 

3. 利用 表格 布局 成 果 

如 图 1-20 所 示 , 当 布局 单元 格 绘制 完毕 ,就 可 以 单 击 布局 模式 中 的 超 链接 【退出 】, 退 出 
布局 模式 。 然 后 ,就 可 以 在 普通 模式 下 直接 向 各 个 区 域 插入 文本 、 图 片 等 各 种 对 象 了 。 
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文件 E) 编辑 全 ) 查看 (中 插入 (I) 修改 (WD 文本 (I) 命令 (C) 站 点 (3 窗口 (WD 帮助 本 
书局 导电 外 [页 上 [拓展 [局 ] 和 天 | 芝 及 说 旷 回 : 国 
EC 


站 | 合 改 因 鸟 | 半 多 下 AAA 


有 有 二 再 


~ 
> 
NA 100% v710x24v 1K/1D 


< 
body) Ctable> tr) CD 


1-20 ”利用 表格 实现 布局 
4. 检查 表格 布局 的 源 代码 


在 如 图 1-20 所 示 的 布局 完成 后 ,切换 到 网 页 的 [代码 ] 视 图 下 ,可 以 发 现 如 图 1-21 所 示 
的 网 页 代码 。 


htnl xmnlns="http: /fny. wi. org/1999/xhtnl > 

《head> 

《meta http-equiv="Content-Type" content="text/htnl; charset=gb2312" /> 
《title) 无 标题 文档 </title>》 

</head> 


<body> 

<table width="767" border="0" cellpadding="0" cellspacing="0"> 
!--DWLayoutDefaultTable-— 
《tr》 

《td height="123" colspan="3" valign="top">!—DWLayoutEmptyCell-——’&nbsp; /td> 

/tr 

《tr> 
《td width="203" height="340" valign="top"><!—DWLayoutEmptyCell--’&nbsp; /td> 
《td width="26")&nbsp; C/+d) 

《td width="538" valign= "top"><!--DWLayoutEnptyCell-—)&nbsp; /td> 

</tr> 

《</table> 

《fbody> 

《Ahtml> 
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通过 网 页 的 源 代码 可 知 , 在 这 种 布局 模式 中 ,系统 是 以 一 个 <table 二 统治 整个 页 面 , 通 
过 在 页 面 中 绘制 了 若干 个 大 小 不 同 的 单元 格 来 实现 布局 。 此 方法 主要 利用 了 表格 中 单元 格 
的 高 度 与 宽度 实现 占 位 ,从 而 达到 了 控制 信息 在 页 面 上 显示 位 置 的 目的 。 


1.3.3 DIV+CSS 布局 


1. 什么 是 DIV+ CSS 布局 


DIV 十 CSS 布局 简称 层 布局 ,就 是 利用 层 对 象 在 页 面 上 实现 布局 的 一 种 方式 。 由 于 这 
种 方式 在 使 用 层 对 象 实现 布局 的 过 程 中 ,往往 需要 借助 样式 来 设置 每 个 层 对 象 的 外 观 、 位 
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置 ,以 达到 布局 页 面 的 目的 。 因 此 这 种 基于 DIV .并 借助 CSS 技术 的 布局 模式 就 被 称 为 
DIV 十 CSS 布局 模式 。 
随 着 Web 2. 0 标准 化 设计 理念 的 普及 ,国内 很 多 大 型 门户 网 站 已 经 纷纷 采用 DIV 十 
CSS 布局 方法 设计 网 页 。 从 实际 应 用 情况 来 看 ,这 一 方法 应 该 优 于 表格 布局 方式 。 由 于 在 
DIV 十 CSS 布局 方式 中 ,将 大 部 分 的 格式 代码 写 在 了 CSS 当中 ,使 得 页 面体 积 变 得 更 小 。 
另外 ,由 于 DIV 十 CSS 将 页 面 独立 成 多 个 独立 的 区 域 ,在 打开 页 面 时 ,可 逐 层 加 载 , 有 利于 
页 面 的 逐 层 调 用 。 

虽然 说 DIV 十 CSS 解决 了 大 部 分 浏览 器 兼容 的 问题 ,但 在 目前 来 看 ,DIV 十 CSS 还 没有 
实现 所 有 浏览 器 的 统一 兼容 ,也 可 能 会 在 部 分 浏览 器 中 出 现 显示 异常 。 尽 管 如 此 ,DIV 十 
CSS 仍然 是 一 种 很 好 的 布局 模式 。 

2. 在 DW 中 实施 层 布 局 

借助 DW 8.0 可 以 直观 地 实施 层 布局 ,其 主要 流程 如 下 。 

1) 进入 层 布局 状态 

首先 ,新 建 HTML 文档 ,等 待 布 局 。 

其 次 ,使 用 菜单 [窗口 >【 层 】 ,打开 [层面 板 , 如 图 1-22 所 示 。 在 图 1-22 中 右 侧 的 区 
域 就 是 [层面 板 。 


查看 加 插入 (I) 修改 (四 文本 (TI) 命令 (C) 站 点 (3 窗口 (WD 帮助 (00 
国 国生 [三 [了 证 ] 号 加 | 三 


[W 本 Qimx vszx25v1x1 朱 用 


1-22 设置 层 布局 面板 


最 后 ,在 【层面 板 中 ,选中 "防止 重 琶 " 复 选 框 ,保证 各 个 层 对 象 不 重生 。 

注意 : 如 果 使 用 多 层 炭 套 的 方式 布局 网 页 , 则 不 可 选中 "防止 重 登 " 复 选 框 。 在 高 版 本 
的 DW 中 ,用 于 布局 的 层 称 为 "AP DIV”。 

2) 插入 层 对 象 

使 用 菜单 [插入 】>【 布 局 对 象 】->【 层 】, 则 立即 向 当前 页 面 内 插入 一 个 层 对 象 。 如 图 1-22 
所 示 , 层 对 象 的 名 字 为 Layerl1。 如 果 需 要 ,可 以 双击 【层面 板 中 的 对 象 名 称 *Layer1”, 然 后 
为 这 个 层 对 象 改 名 。 

单 击 【设计 了 视图 中 的 层 对 象 ,选中 它 。 此 时 在 层 对 象 的 顶点 和 每 边 的 中 间 位 置 会 出 现 
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操作 句柄 (小 方块 ) 。 拖 动 句柄 ,可 以 直观 地 改变 层 对 象 的 宽度 和 高 度 。 

如 果 让 鼠标 指向 层 对 象 边缘 的 非 句柄 位 置 , 则 鼠标 指针 变 成 带 有 箭头 的 十 字 状 ,此 时 可 
以 拖 动 鼠标 ,改变 层 对 象 的 位 置 。 

在 【 层 】 面 板 中 , 单 击 层 名 称 前 面 . 眼 睛 对 应 的 列 ,将 会 在 该 位 置 出 现 一 只 眼睛 图 标 。 如 
果 眼 睛 处 于 睁 开 状态 ,这 个 层 对 象 就 会 在 [设计 了 视图 中 显示 为 一 个 矩形 虚 框 。 这 个 矩形 虚 
框 的 存在 ,能 够 帮助 开发 者 明确 此 处 已 经 配置 了 层 对 象 。 当 然 , 开 发 者 也 可 以 通过 再 次 单 击 
这 列 中 的 个 别 眼睛 图 标 , 使 眼睛 闭 上 ,使 相应 层 对 象 暂 不 显示 ,使 设计 视图 显得 整洁 。 

用 同样 的 方法 ,向 设计 视图 中 插入 若干 个 层 对 象 ,并 对 层 对 象 的 摆 放 位 置 进行 调整 ,使 
各 个 层 对 象 互 不 重 释 ,而 且 能 够 在 未 来 各 自 承担 一 定 的 责任 。 例 如 ,顶部 的 层 对 象 常 常 放置 
网 站 的 Logo, 底 部 的 层 对 象 则 被 用 来 放置 版 权 页 信息 , 左 侧 的 层 对 象 通常 充当 目录 

3) 设置 层 对 象 的 样式 

利用 菜单 [窗口 >【CSS 样式 ] 切 换 到 【CSS 样式] 面板 。 此 时 ,可 以 看 见 所 有 的 层 对 象 
都 显示 在 【CSS 样式 ] 面 板 中 。 

选 定 其 中 的 一 个 层 对 象 , 右 击 后 选择 [编辑 】, 则 打开 层 对 象 样式 编辑 器 ,如 图 1-23 所 示 。 


[ea 


#Top 的 CSS 规则 定义 


RO: 
至 景 图 缠 OD: haw_risht at 。 国 
重复 国 ): ~ 
附件 四); 


水 平 位 置 加 ) | 
垂直 位 置 中) ~ 
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通过 此 编辑 器 可 以 设置 这 个 层 对 象 的 背景 . 方 框 ,以 及 其 中 文字 的 样式 等 。 但 是 ,在 此 
界面 下 ,尽量 不 要 改变 层 对 象 的 宽度 .高度 和 摆 放 位 置 等 信息 。 

4) 检查 层 布局 的 源 代 码 

针对 一 个 已 经 定义 了 顶部 Logo 区 , 左 侧目 录 区 、 底 部 版 权 页 和 中 部 主 信息 区 的 层 布局 
页 面 , 切 换 到 网 页 的 [代码 了 视图 下 ,可 以 发 现 如 图 1-24 所 示 的 网 页 代码 。 

从 图 1-24 中 可 以 看 出 ,本 过 程 一 共 定义 了 4 个 DIV 对 象 ,名 字 为 top、 left、 main、 
bottom, 而 且 在 网 页 的 开始 部 分 通过 二 style 二 过 /style 二 实施 了 级 联 的 内 肉 式 样式 ,分 别 对 
每 个 层 对 象 的 位 置 、 高 度 ,宽度 进行 了 定义 。 而 且 , 针 对 TOP 对 象 ,还 利用 属性 background- 
image 标记 设置 了 这 个 层 对 象 的 背景 。 

通过 阅读 层 布局 的 源 代码 ,可 对 DIV 十 CSS 布局 的 含义 有 了 比较 彻底 的 认识 。 


1.3.4 以 框架 技术 实施 布局 
一 个 网 站 通常 由 众多 网 页 组 成 ,这 些 网 页 常常 使 用 相同 的 页 面 结构 ,而 且 这 些 网 页 的 
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Logo 区 域 . 目 录 区 、 版 权 页 等 区 域 具 有 比较 稳定 、 基 本 不 变 的 特点 ,而 变化 最 为 频繁 的 就 是 
内 容 区 部 分 。 为 此 在 网 页 设计 中 引入 了 多 种 技术 ,主要 有 框架 技术 、DW 的 模板 技术 、 
VS2008 的 母 版 页 技术 。 


htnl xmlns="http: / /nr. w3. org/1999/xhtnl” > 
head> 
neta http-equiv="Content-Type" content="text/htnl; charset=gb2312" /> 
《tit1e) 无 标题 文档 《/title> 
《style type="text/css">¢!— 
#Top { 
position:absolute; width:793px; height:11l5px; z-index:1; 
left: 9px; top: 9px; visibility: visible; 
background-image: url(glbnav right. gif); 
} 
#left { 
position:absolute; width: 200px; height:67dpx; z-index:2; 
left: lO0px; top: 124px; visibility: visible; 
} 
tmain { 
position:absolute; Width;578px helght;668px 
z-index:3; left: 227px; top: 125px; visibility: visible; 


#Bottom { 
position:absolute; width:792px; height:63px; z-index:1; 
left: 2px; top; 789px, visibility: visible 


—>K/style> 
《jhead> 


body> 
Cdiv id-"Botton">C/div> 

《div id"Top">/div> 

div id="left”align="right">C/div> 
Cdiv i "nain’>C/div> 


<fbody> 
Jhtnl> 
1-24 ” 层 布 局 的 源 代码 
1. 什么 是 框架 


所 谓 框架 ,就 是 通过 一 定 的 技术 手段 把 页 面 划分 为 若干 个 区 域 ,在 每 个 区 域 中 可 显示 一 
个 独立 的 HTML 文件 。 在 这 一 结构 中 ,每 个 区 域 被 称 为 一 个 框架 ,描述 全 体 框架 组 成 结构 
的 文档 称 为 框架 集 。 从 另 一 个 角度 讲 , 框 架 集 可 以 把 若干 个 网 页 组 织 到 一 个 页 面 中 。 在 这 
个 结构 中 ,填充 局 部 区 域 (框架 ) 的 网 页 称 为 子 网 页 ,而 总 揽 全 体 网 页 组 织 结构 的 页 面 就 是 杠 
架 集 。 框 架 集 通 常 不 处 理 具体 的 显示 内 容 , 仅 负责 页 面 区 域 的 划分 。 

在 框架 结构 下 ,每 个 子 网 页 可 以 独立 地 被 切换 ,因此 特别 适合 网 站 中 大 量 区 域 稳定 、 少 
量 局 部 区 域 变化 频繁 的 情况 。 

2. 在 DW 中 实现 框架 

在 DW 中 ,可 以 有 两 种 方式 实现 框架 。 

1) 利用 新 建文 件 创建 框架 集 

首先 ,启动 DW 8.0, 选 择 [ 文 件 ]>【 新 建 〗 从 [常规 ] 选 项 卡 中 选择 [框架 集 】, 如 图 1-25 
所 示 。 然 后 ,可 从 框架 集中 选择 所 需 的 结构 。 最 后 , 单 击 【 创 建 ] 按 钮 。 

此 时 DW 要 求 确认 每 个 框架 的 名 称 ,如 图 1-26 所 示 。 如 果 采 用 默认 名 称 , 则 可 直接 单 
击 【 确 定 ] 按 钮 。 此 时 ,DW 会 创建 一 个 新 的 网 页 ,并 进入 到 网 页 编辑 状态 。 
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入 门 页面 
页 面 设 计 ( 有 辅助 功能 的 》 


rn 框架 标签 辅助 功能 属性 
es 


DDODDDDDDODDOODD 


文档 类 型 0TD) : 
ML 1 0 Transitional 


[Ev 


图 1-25 新 建 框架 集 图 1-26 设置 各 个 框架 的 名 称 


2) 利用 修改 功能 把 网 页 划分 为 若干 区 域 

首先 ,新 建 一 个 普通 网 页 ,进入 到 网 页 的 【设计 了 视图 下 ; 然后 ,使 用 菜单 [修改 ]>【 框 架 
页 】, 各 种 框架 划分 结构 将 以 子 菜单 项 的 模式 提供 开发 者 选用 。 此 时 ,可 从 子 菜单 中 选择 所 
需 的 结构 ,把 当前 光标 所 在 的 区 域 进行 拆 分 。 

3. 对 框架 实施 配置 

1) 修改 框架 属性 

首先 ,利用 菜单 [窗口 >【 框 架 ] 打 开 [ 框 架 ] 面 板 ,使 之 显示 在 DW 的 右 侧 区 域 。 在 【 框 
架 ] 面 板 中 ,各 个 框架 按照 在 页 面 中 的 位 置 和 大 小 构成 了 一 个 框架 集 的 示意 图 。 

其 次 ,通过 单 击 [ 框 架 ] 面 板 中 的 某 个 框架 ,选中 它 。 此 时 位 于 页 面 底部 的 [属性 ] 面 板 会 
变 成 针对 选中 框架 的 面板 ,可 以 便利 地 进行 设置 ,如 图 1-27 所 示 。 

ONMacromnedia Dreamweaver 8 [UntitledFrameset-8 (XHTML)#] 


俞 令 C) 站 点 (3) 官 口吃 帮助 (B) 


边界 宽度 
这 界 高 度 | 


图 1-27 利用 框架 布局 的 主 界面 
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。 通过 [边框 项目 可 设置 当前 框架 的 边框 ,包括 是 否 显示 边框 ,边框 的 颜色 。 
。 通过 【滚动 3 项 目 可 设置 当前 框架 是 否 带 有 滚动 条 。 
。 通过 【 源 文件 ] 项 目 可 设置 当前 框架 中 默认 显示 的 网 页 文件 名 。 
2) 使 超 链接 结果 显示 到 指定 框架 中 
当 框 架 被 定义 后 ,其 名 称 就 可 以 被 应 用 到 超 链接 中 。 框 架 名 称 通常 可 被 超 链 接 中 的 
target 属性 使 用 ,表示 在 指定 的 框架 内 显示 被 链接 网 页 的 内 容 。 
在 如 图 1-27 所 示 的 框架 设计 中 , 右 侧 的 大 面积 区 域 被 定义 为 main 框架 ,在 左 侧 定义 了 
两 门 课程 “计算 机 原理 ”和 “操作 系统 ”。 假 设 这 两 门 课程 对 应 的 首页 文件 名 分 别 为 
computer. htm 和 os. htm, 如 果 和 希望 “计算 机 原理 ”和 “操作 系统 ”链接 的 内 容 将 来 显示 在 
main 框架 内 ,那么 超 链接 语句 可 以 书写 为 如 下 格式 : 
<a href = computer. htm target = main> 计 算 机 原理 </a> 
<a href = os.htm target = main > 操作 系统 </a> 
位 于 过 a> 标 记 内 部 的 子 语句 “target=main” 指 明了 此 超 链接 结果 的 输出 位 置 是 框架 
main。 
除了 框架 名 称 可 作为 超 链 接 的 target 属性 值 之 外 ,HTML 体系 还 内 置 了 4 个 特殊 的 标 
记 , 都 可 以 作为 超 链接 的 输出 目标 (target 属性 的 值 ) ,依次 为 : 
。 _blank ,表示 输出 到 一 个 新 的 ,空白 的 窗口 中 。 
。 _top, 如 果 存 在 多 重 框架 , 则 输出 到 顶级 窗口 中 。 
。 _parent, 如 果 存 在 多 重 框架 , 则 输出 到 当前 框架 的 上 一 级 框架 中 。 
。 _self, 输 出 到 与 当前 文档 相同 的 框架 中 。 
在 实施 超 链 接 时 ,系统 默认 Target 的 值 为 ”self”。 
4. 对 框架 的 小 结 
1) 框架 集 的 代码 
打开 前 面 定义 的 框架 集 文件 ,切换 到 [代码 芒 式 下 ,观察 框架 集 文件 的 代码 ,如 图 1-28 所 示 。 


CIDOCTYPE htnl PUBLIC ™-/77W3C77DTD 3HTIL 1.0 Franeset//EN™ 

"http: /finnw. w3. org/TR/xhtnl1/DTD /xhtnll-franeset. dtd"> 

htnl xmlns="http: /ww. w3. org /1999/xhtnl"> 

<head> 

neta http-equiv="Content-Type" content="text/htnl; charset=gb2312" /> 

《title》 无 标题 文档 《/title>》 

《Ahead> 

Kfraneset rows="*" cols="267, 504"> 
《frameset rows="101, 295" cols="*"> 


《frane src="" id-"LeftGao" /> 
《frane src="" id-"Left" /> 
/frameset> 
《frane src="" id-"NMain" /> 


/franeset> 
nofranes> <body> 


《jbody> 
/nofranes>/htnl> 


1-28 ”框架 集 代码 


从 图 1-28 中 可 以 看 出 ,此 文件 由 两 个 frameset 构成 ,其 中 的 一 个 frameset 被 艇 套 在 另外 
一 个 frameset 之 中 。frameset 中 的 每 个 frame 都 有 自己 独立 的 名 称 ,以 便 超 链接 时 使 用 。 
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2) 框架 技术 的 缺陷 

框架 技术 虽然 较 好 地 解决 了 屏幕 区 域 划 分 的 问题 。 通 过 框架 技术 ,开发 者 可 以 便利 地 
实现 页 面 布局 ,开发 出 内 容 固定 区 域 与 内 容 多 变 区 域 有 机 组 合 的 网 站 。 

然而 ,由 于 在 使 用 框架 技术 的 过 程 中 ,人 为 地 把 屏幕 切割 为 若干 视窗 ,分 别 显示 不 同 内 
容 的 网 页 ,导致 整个 页 面 的 一 致 性 较 难 协调 ,页 面 中 的 各 框架 网 页 之 间 常 常 出 现 过 渡 生 硬 的 
问题 ,影响 了 网 站 的 质量 。 


1.3.5 以 Photoshop 实施 布局 


在 网 页 设计 的 实践 中 ,人 们 逐渐 发 现 无 论 是 表格 布局 ,还 是 层 布局 ,框架 布局 ,如 果 基 于 
人 工 方式 在 DW 下 绘制 区 域 并 设置 各 个 区 域 的 样式 ,虽然 能 够 实现 布局 结构 ,但 最 终 的 输 
出 效果 总 是 不 尽 如 人 意 ,给 最 终 用 户 一 种 过 渡 生 硬 、 页 面 质量 不 高 的 感觉 。 

为 此 ,很 多 网 页 设计 者 开始 思考 能 否 借助 图 像 处 理工 具 实 现 布 局 : 开发 者 可 以 像 绘制 
图 片 和 进行 图 像 处 理 一 样 先 绘制 出 整个 页 面 ,使 整个 页 面 成 为 一 幅 和 谐 的 图 片 ; 然后 利用 
特定 的 工具 把 图 片 划分 为 若干 个 区 域 ,最 后 再 分 别 向 不 同 的 区 域内 填 入 内 容 。 在 这 一 模式 
下 ,由 于 整个 页 面 基于 一 幅 和 谐 的 图 片 ,使 网 页 内 容 的 展示 就 像 在 呈现 一 幅 和 谐 ,精美 的 画卷 。 

基于 这 一 理念 ,Photoshop 和 Fireworks 成 为 了 网 页 布局 的 重要 工具 。 总 结 它们 实现 
网 页 布局 的 基本 流程 ,可 知 其 关键 步骤 是 由 Photoshop 和 Fireworks“ 绘 制 页 面 , 切 割 页 面 、 
存 成 网 页 ”, 然 后 由 DW* 负 责 修缮 ”。 

1. 在 Photoshop 下 进行 页 面 处 理 

1) 创建 空白 的 图 像 文件 

在 Photoshop 中 ,新 建 一 个 1024X768 像素 或 者 高 度 更 大 的 图 像 文 件 。 

2) 在 图 像 顶 部 设计 网 页 的 Logo 区 域 

首先 ,为 Logo 区 域 粘贴 所 需 的 图 像 。 在 设计 Logo 区 域 的 图 像 时 ,经 常 要 用 到 图 像 的 
编辑 技术 。 使 用 最 为 频繁 的 技术 有 : 从 其 他 图 像 文件 中 复制 部 分 图 像 ,创建 新 图 层 , 删 除 羽 
化 的 选区 。 另 外 ,对 Photoshop 工作 区 中 的 某 些 对 象 进行 自由 变换 .设置 并 调整 亮度 等 操作 
较为 常用 。 

其 次 ,输入 Logo 文字 。 在 输入 Logo 文字 后 ,常常 对 Logo 文字 使 用 “ 滤 镜 "和 “图 层 样 
式 ”, 使 文字 显示 为 较 理想 的 效果 。 

3) 绘制 网 页 上 各 个 区 域 

利用 图 形 工具 在 页 面 上 绘制 各 个 区 域 , 并 适当 设置 各 个 区 域 中 相关 图 形 的 样式 。 在 这 
个 过 程 中 ,经 常 使 用 以 下 技巧 。 

(1) 如 果 对 其 他 网 站 中 的 某 些 区 域 比较 满意 ,也 可 以 首先 利用 PrintScreen 键 复制 屏幕 
内 容 ; 然后 利用 “粘贴 ”功能 把 该 界面 粘贴 到 Photoshop 中 ; 接着 使 用 选区 工具 选 定 所 需 的 
区 域 ,把 它 粘贴 到 当前 的 页 面 中 ;最 后 使 用 "自由 变换 ?工具 调整 区 域 的 大 小 、 位 置 。 

(2) 为 各 个 区 域 输入 固定 的 文字 ,例如 区 域 的 标记 、 菜 单项 等 ,并 设置 文字 的 特殊 效果 。 

(3) 利用 Photoshop 的 “修补 工具 ”对 工作 区 中 的 部 分 区 域 进行 清理 ,替换 掉 不 需要 的 
标记 。 

注意 : 此 时 不 要 输入 内 容 性 文字 ,内 容 性 文字 应 该 在 DW 中 输入 。 对 于 以 后 计划 输入 
内 容 性 文字 的 区 域 , 尽 量 使 用 单一 颜色 (纯色 ) 作 为 背景 。 
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4) 保存 为 psd 文档 
当 整 个 页 面 绘制 完 毕 , 基 本 达到 要 求 后 ,可 把 Photoshop 格式 的 图 形 文件 保存 起 来 , 即 
保存 为 . psd 格式 文档 ,如 图 1-29 所 示 。 


图 1-29 绘制 网 页 的 主体 结构 


注意 : 此 时 最 好 保留 所 有 图 层 和 历史 记录 ,以 备 未 来 修改 页 面 布局 时 使 用 。 
2. 对 Photoshop 图 像 切片 
) 用 切片 工具 对 图 像 实现 切片 
利用 Photoshop 的 切片 工具 对 图 1-29 所 示 的 左 侧 区 域 (目录 区 域 ) 和 右 侧 区 域 (显示 内 
容 的 区 域 ) 分 别 切 片 , 切 出 两 个 可 以 存放 数据 的 矩形 区 域 ,结果 如 图 1-30 所 示 ( 界 面 上 标记 
为 03,05)。 这 是 两 个 用 户 切片 ,其 他 区 域 被 系统 自动 切割 ,成 为 自动 切片 。 

当然 ,开发 者 可 以 根据 需要 切 出 更 多 的 切片 。 

2) 对 用 户 切片 的 纯色 区 域 进行 处 理 

首先 ,在 【切片 工具 状态 下 右 击 页 面 上 的 左 侧切 片 ,选择 菜单 【编辑 切片 选项 】, 则 打开 
【切片 选项 ] 对 话 框 ,如 图 1-31 所 示 。 

其 次 ,选择 [切片 类 型 ] 为 “无 图 像 ”, 选 择 【切片 背景 类 型 ] 为 “其 他 ”。 系 统 将 自动 弹出 
【 拾 色 器 (吸管 )] 对 话 框 ,此 时 鼠标 指针 变 成 “吸管 "状态 ,直接 单 击 主 窗 口中 的 那个 切片 ,使 
此 切片 的 颜色 成 为 本 区 域 的 背景 色 。 

最 后 , 单 击 【 确 定 ] 按 钮 ,确认 对 切片 状态 的 设置 。 

注意 : 对 不 是 纯色 的 切片 不 要 进行 上 述 操作 ,否则 会 导致 该 切片 区 域 变 成 纯色 而 失去 
Photoshop 布局 的 初衷 。 对 这 种 区 域 的 处 理 ,需要 在 DW 下 完成 。 

3. 另存 为 Web 文档 

切片 完成 后 ,选择 菜单 [文件 ]- 江 存储 为 Web 和 设备 所 用 格式 】, 从 对 话 框 底部 单 击 【 存 
储 ] 按 钮 ,系统 将 弹出 [将 优化 结果 存储 为 3 对 话 框 ,如 图 1-32 所 示 。 
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@ Adobe Photoshop - [ooo- jpg @ 66.1%(RGB/8)] 加 Ey 
ET 护 间 外 图 当中 本山 碗 其 人 话 席 中 视 用 窗口 ) 帮助 人 - S 
x 


Pp .3 图 下 反 [ie 


1-30 对 页 面 实施 切片 


Photoshop 支持 把 网 页 保存 为 表格 方式 布 
局 和 层 方式 布局 两 种 形式 ,只 需 在 图 1-32 所 示 SEE 
界面 中 对 【设置 ] 对 话 框 进行 必要 的 设置 。 其 具 | gznwz#0y 
体 过 程 为 : 

首先 ,选择 【保存 类 型 ] 为 “HTMLIL 和 图 
像 ”, 而 且 是 保存 所 有 切片 。 

然后 ,从 【设置 I 下 选择 “其 他 ”, 打 开 [ 输 出 
设置 ] 对 话 框 ,接着 可 根据 布局 类 型 要 求 分 别 进 


切片 选项 


行 如 下 设置 
1) 表格 方式 布局 
在 [ 答 出 设置 了 对话 框 中 选择 * 切 片 ", 选 中 


【生成 表格 了 单 选 按钮 ,而 且 选择 对 于 每 个 单元 
格 的 [TD W& H] 为 “总 是 "。 即 对 每 个 单元 格 都 明确 地 标记 出 其 长 度 和 宽度 ,如 图 1-33 所 
示 。 然 后 单 击 【确定 按钮 确认 这 一 设置 ,返回 到 【将 优化 结果 存储 为 3 对话 框 。 

2) CSS 十 DIV 方式 布局 

在 [输出 设置 ] 对 话 框 中 选择 “切片 ”, 然 后 设置 【生成 CSS] 单 选 按钮 生效 ,如 图 1-34 所 
示 。 最 后 , 单 击 【 确 定 ] 按 钮 确认 刚才 的 设置 ,返回 到 [将 优化 结果 存储 为 ] 对 话 框 。 

3) 保存 Web 页 

回 到 【保存 优化 结果 对话 框 , 单 击 按钮 【保存 按钮 ,开始 实现 保存 网 页 文件 操作 。 此 
时 ,系统 将 自动 生成 一 个 HTML 文档 和 一 个 Images 文件 夹 ,HTML 文档 中 存储 格式 说 明 ,而 
Images 文件 夹 中 存储 了 多 个 图 片 文件 ,是 执行 切片 操作 后 由 Photoshop 自动 生成 的 图 像 文 件 。 


将 优化 结果 存储 为 
Dee _ 6) 


局 360Domloadz 
Dook 
Book2011 

已 Course 
Detp 
DFavoriteVideo 
lmhd 

Dm 

局 myDocunent 
Dnevieb 
pjsys 
BProgher 

局 ProgranData 
Dtest 

DrsTest 


已 idc 
rordr 

已 zalv 
ra 

垃 soban2.htal 
疾 aoban3.htal 


文件 名 加 oo0. htal 


保存 闪 型 中 。 | TIL 和 图 像 .htal) 


切片 


输出 设置 


空间 元 格 :| GIY,，IW6 Yak 


TD 


分 了 和 罕 单元 格 -” 生动 ( 底部 ) 


口 4 威 SS 


陵 认 切片 命名 
文档 名 称 


[SE 
无 
元 全 rile ol 


图 1-33 


输出 设置 


陵 认 切片 龟 名 


1-32 存储 优化 结果 的 对 话 框 


选择 表格 布局 方式 


[各 5 称 


图 是 名称 或 说 片 所 号 


无 


示例 yfile ol 


图 1-34 设置 DIV 十 CSS 布局 方式 


网 页 设计 基础 
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4. 在 DW 下 修正 页 面 
在 DW 下 ,打开 刚刚 以 Photoshop 制作 的 页 面 ,如 图 1-35 所 示 。 
weaver WE 2004 [ooo (桌面 /oo00. hta1*)] 


查看 @ 插入 0) 修改 他 文本 四 命令 CC) 站 点 G) 窗口 中 帮助 吕 
图 目 艇 [全 [ 攻 虹 | 有 局] 二 可 | 芝 忆 视听 回 - 园 


> 
Coody> Ceenter> ctsble# 01> Cr> Co Tigx332.67K/10 秒 


BZ 匡 委 重 面 钳 接 册 ) 

由 [| 二 和 本 要 上 标 D 
国 元 格 水 平 @ 陵 认 间 宽 如 R27 ] 大 执行 四 口 育 最 加 Feagez/ooo .05 jp ] 
OK VR VW ] OD RMNe GT| 这 四 [ 


1-35 打开 Photoshop 布局 的 Web 页 面 


1) 处 理 纯色 切片 区 域 

用 鼠标 单 击 左 侧 的 目录 区 域 。 由 于 此 区 域 是 已 经 在 Photoshop 中 被 设置 为 无 图 像 和 背 
景色 的 切片 ,因此 ,可 以 选中 此 图 片 ,然后 按 Del 键 ,删除 此 切片 中 的 图 片 。 

此 时 ,此 区 域 中 已 经 没有 任何 元 素 ,成 为 一 个 可 以 输入 数据 的 区 域 。 由 于 此 区 域 已 经 在 
Photoshop 中 设置 背景 色 ,不 会 影响 区 域内 的 显示 效果 。 

2) 在 [设计 了 视图 下 处 理 带 有 图 像 的 切片 区 域 

对 于 带 有 图 像 的 切片 区 域 ,如 果 想 在 此 区 域 输入 信息 而 不 影响 原 有 显示 效果 , 则 需要 把 
此 处 的 切片 图 片 变 成 背景 。 其 具体 操作 方法 如 下 。 

(1) 在 [设计 了 视图 下 , 单 击 该 切片 区 域 ,会 发 现 此 区 域 是 一 个 图 片 , 从 它 的 [属性 了 面板 
中 剪 切 此 图 片 的 文件 名 。 

(2) 从 【设计 视图 底部 选择 最 右 侧 的 那 一 个 <TD 二 或 <DIV 二 ,打开 其 [属性] 面板 ， 
把 刚刚 剪 切 的 文件 名 粘贴 到 其 [属性 了 面板 的 “背景 "文本 框 中 。 

(3) 最 后 ,直接 用 Del 键 删除 该 切片 区 域 中 的 图 片 。 

3) 在 [代码 7 方式 下 处 理 带 有 图 像 的 切片 区 域 

对 于 带 有 图 像 的 切片 区 域 ,如 果 想 在 此 区 域 输入 信息 而 不 影响 原 有 显示 效果 , 则 需 
要 把 此 处 的 切片 图 片 变 成 背景 。 对 于 这 一 操作 ,也 可 以 直接 在 代码 方式 下 完成 。 其 具体 
方法 如 下 。 

(1) 在 DW 的 【设计 了 视图 下 ,用 鼠标 单 击 某 一 带 有 图 像 的 区 域 ,由 于 此 区 域 是 在 
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Photoshop 中 被 切割 为 图 像 的 切片 ,所 以 该 区 域 中 的 图 片 会 被 选中 。 例 如 ,选中 右 部 的 蓝 色 
大 切片 。 

(2) 选择 【查看 】 拭 代码 】, 切 换 到 网 页 的 【代码 了 视图 状态 。 如 果 该 网 页 采取 表格 布局 
方式 ,就 会 发 现 如 图 1-36 所 示 的 效果 。 


《img src=" images/jj 02. gif” width=" 33" height="283" alt=""></td> 
<td width="116" height="150" colspan="2" bgcolor=" #C17474" > 

《img src="images/ 分 隔 符 .gif” width="116" height="150" alt="">《/td 
《td rowspan=" 2 > 

《ing src= "inages/ jj 04. gif" width="42" height="194" alt="">/+td> 


《img src="images/jj_06. gif" width="66" height="283" alt="">/td> 


《td colspan="2"> 
《img src="images/jj_07.gif" width="116" height="44" alt="">/td> 


Cltr> 


图 1-36 处理 Photoshop 的 表格 布局 


从 图 1-36 中 可 以 看 出 ,系统 是 在 单元 格 中 插入 了 一 个 宽度 为 169 ,高 度 为 194、 名 字 为 
jj_05. gif 的 图 片 , 只 须 把 此 图 片 转化 为 单元 格 的 背景 即 可 。 

首先 ,选中 文字 “"images/jj_05. gif"” width 王 "169" height="194"”, 并 移动 到 二 td 之 标 
记 内 部 。 

其 次 ,在 标记 <td> 内 部 进行 修改 ,把 原来 的 图 片 变 成 td 的 背景 , 即 修改 为 <td backgroud 二 
"images/jj_05. gif” width="169" height="194"> 形 式 。 

最 后 ,删除 多 余 的 标记 过 img src=""alt="" 之 。 最 终 的 效果 如 图 1-37 所 示 。 就 实现 了 
把 切片 图 像 变 成 区 域 背景 的 目的 。 


《img src= inages/ 分 隔 符 . Si vidth="116" height="150" alt="™">C/td> 
《td rowspan=" "2" > 
《img src= "inages/jj- 4, gif" A 
《<td colspar="2"”rowspan="2"” 本 169”height= 194 
《ftd> 
《td rowspar="d"> 
《img src="images/jji_06. gif" width="66”height="283”alt="" >C/td> 


Wtr> 
<tr> 
《td colspan="2"> 
img src="images/jj_07.gif" width="116" height="44" alt="">C/+td> 


/tr> 


图 1-37 设置 单元 格 的 背景 属性 


如 果 该 网 页 采取 层 布 局 方式 , 则 需要 进行 如 下 操作 。 

首先 ,查看 与 选中 图 片 最 近 的 天 DIV 二 标记 的 ID 号 ,并 复制 此 图 片 的 文件 名 。 

其 次 ,到 网 页 首部 的 样式 表 中 (<style 之 一 /style 之 ) 查 找 对 应 的 ID 标记 ,并 在 此 标记 
的 样式 中 增加 一 行规 则 “background-image:url( 图 片 文件 名 );”, 然 后 把 刚刚 复制 的 文件 名 
粘贴 到 规则 中 的 “图 片 文件 名 ”位 置 。 

(3) 最 后 ,返回 到 【设计 了 视图 ,直接 用 Del 键 删除 此 区 域内 的 图 片 。 

(4) 同 理 , 对 其 他 的 切片 实施 处 理 。 
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4) 在 输入 页 面 中 插入 其 他 信息 

经 过 前 述 处 理 ,此 时 切片 内 的 图 形 已 经 变 成 了 图 像 背 景 。 用 户 切片 对 应 的 区 域 中 已 经 
没有 了 占 位 的 图 形 。 因 此 ,可 以 在 【设计 了 视图 中 直接 向 各 个 区 域内 输入 数据 ,不 会 影响 切片 
区 域 的 显示 效果 。 

在 各 个 区 域内 输入 恰当 的 文字 内 容 、 插 入 图 像 ,并 保存 此 页 面 。 

5) 为 菜单 项 设置 热点 链接 

利用 前 面 讲述 的 创建 “热点 链接 ”的 方法 ,为 图 片 中 的 “首页 "“ 领 导 风 采 ”“ 机 构 设置 
等 建立 热点 型 的 超 链接 ,使 这 些 菜单 项 指向 对 应 的 网 页 文件 。 

注意 : 输入 内 容 不 要 溢出 切片 区 域 的 大 小 。 否 则 ,可 能 导致 页 面 布局 散 架 。 

5. 以 Photoshop 实施 布局 的 小 结 

基于 上 述 流程 ,笔者 认为 ,以 Photoshop 实现 布局 主要 包括 以 下 环节 。 

1) 利用 Photoshop 绘制 主 界面 

充分 地 利用 Photoshop 的 图 片 编辑 工具 ,通过 调整 图 像 亮 度 , 使 用 修补 工具 、 羽 化 工具 、 
自由 变换 工具 、 图 形 绘制 工具 文字 工具 、 图 层 样式 工具 、 滤 镜 工具 ,以 及 图 片 的 选区 、 复 制 与 
粘贴 ,为 网 页 主 界面 设计 出 一 幅 和 谐 , 美 丽 的 图 片 。 

当然 ,在 这 一 过 程 中 ,要 充分 地 注意 网 页 自身 的 特点 ,兼顾 网 页 的 风格 要 求 , 少 用 对 比 度 
过 大 的 图 片 ,并 注意 屏幕 区 域 的 划分 。 为 提升 网 页 的 运行 效率 , 尽 可 能 把 需要 输入 文本 信息 
的 大 块 区 域 设 置 为 单一 颜色 的 背景 。 

最 后 ,把 制作 好 的 图 片 保存 为 psd 文档 ,以 备 未 来 修改 时 使 用 。 

2) 实现 切片 

在 前 述 设计 效果 的 基础 上 ,可 先 拼 合 图 层 ; 然后 利用 【切片 3 工具 切割 图 形 界 面 , 为 各 个 
区 域 切割 出 用 户 切 片 。 

对 于 采用 单一 颜色 做 背景 的 切片 ,可 删除 此 切片 中 的 图 像 ,把 其 背景 色 修改 为 当前 图 片 
的 颜色 。 

在 必要 的 情况 下 ,甚至 可 以 利用 借助 Photoshop 制作 翻转 图 。 

3) 另存 为 Web 文档 

在 Photoshop 下 ,选择 [文件 ]>【 存 储 为 Web 所 用 格式 】, 把 刚刚 完成 切片 的 整个 图 像 
存储 为 Web 文档 ,并 可 根据 自己 的 习惯 ,选择 布局 类 型 ,确定 是 采用 表格 布局 ,还 是 使 用 层 
布局 。 

4) 在 DW 下 对 Photoshop 生成 的 网 页 实施 处 理 

在 DW 的 [设计 了 视图 下 ,可 直接 删除 纯色 切片 区 的 占 位 图 片 ,然后 把 非 纯色 区 域 的 占 
位 图 片 变 成 相应 区 域 的 背景 ,并 在 用 户 切 片区 域 输入 合适 的 内 容 。 


1.3.6 模板 技术 


1. 模板 的 定义 

由 于 网 站 中 的 多 个 网 页 常常 使 用 相同 的 页 面 结构 ,在 这 些 网 页 中 ,其 Logo 区 域 .目录 
区 \ 版 权 页 等 区 域 都 比较 稳定 ,具有 基本 不 变 的 特点 ,常常 只 有 内 容 区 域 变 化 频繁 。 在 一 个 
网 站 中 ,如 果 涉 及 上 百 个 页 面 的 Logo 区 或 者 版 权 页 区 要 发 生变 化 ,其 修改 的 工作 量 是 非常 
大 的 。 为 此 ,DW 引入 了 模板 技术 。 由 于 在 动态 网 站 开发 中 , DW 的 模板 技术 可 以 被 
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VS2008 的 母 版 页 技术 代替 ,因此 本 节 仅 简要 地 介绍 。 

所 谓 模板 ,就 是 快速 生成 网 页 的 模具 。 利 用 模板 ,可 以 快速 地 生成 一 批 网 页 ,这 些 网 页 
都 具有 完全 相同 的 结构 ,开发 者 可 以 根据 需要 对 新 网 页 的 特定 区 域 进行 修改 ,从 而 高 效率 地 
设计 一 批 风格 一 致 的 页 面 。 

2. 模板 设计 过 程 

1) 创建 站 点 

模板 的 设计 与 使 用 建立 在 站 点 的 基础 上 ,因此 创建 模板 前 必须 创建 DW 站 点 。 

2) 创建 模板 页 

首先 ,新 建 一 个 网 页 ,对 网 页 进行 布局 ,可 输入 所 有 的 固定 内 容 。 

其 次 ,使 用 菜单 [文件 ]>【 另 存 为 模板 】 ,设置 文 件 名 后 ,执行 [保存] 操作 ,就 会 自动 生成 
模板 页 文件 。 模 板 页 文件 被 存放 在 站 点 的 Templates 文件 夹 中 ,自动 以 . dwt 作为 扩展 名 。 

第 三 ,将 光标 放 到 经 常 需要 改变 内 容 的 区 域 , 然 后 执行 命令 【插入 】>【 模 板 】>【 可 编辑 
区 域 】, 给 予 此 区 域 一 个 名 称 后 , 即 可 单 击 【确定 ] 按 钮 ,确认 此 区 域 为 可 编辑 区 域 。 

第 四 ,以 同样 的 方法 ,可 以 把 多 个 区 域 分 别 设置 为 “可 编辑 区 域 ”。 

最 后 ,保存 模板 页 文件 。 

注意 : 为 了 达到 精美 .和 谐 的 效果 ,建议 直接 采用 以 Photoshop 布局 的 页 面 作为 模板 页 。 

3. 利用 模板 页 创建 网 页 

当 站 点 中 已 经 有 了 模板 页 后 ,就 可 以 依靠 模板 页 快速 地 生成 网 页 了 。 其 具体 过 程 是 : 

首先 ,选择 菜单 [文件 ]>【 新 建 】, 此 时 系统 打开 [新 建文 档 ] 对 话 框 。 单 击 对 话 框 顶 部 的 
【模板 】 选 项 卡 ,该 对 话 框 变 成 了 【从 模板 创建 ] 对 话 框 。 此 时 ,从 中 选择 一 个 模板 ,然后 单 击 
底部 的 [创建 ] 按 钮 ,就 会 创建 一 个 与 模板 相同 的 新 网 页 。 

其 次 ,在 新 网 页 下 ,只 须 输入 只 属于 这 个 网 页 的 .具有 特色 的 内 容 。 因 为 其 他 的 内 容 已 
经 自动 从 模板 中 继承 ,而 且 只 有 在 模板 中 标记 为 可 编辑 区 域 的 位 置 是 可 以 输入 内 容 的 。 

最 后 ,保存 新 网 页 即 可 。 

4. 利用 模板 批量 更 新 网 页 

由 模板 创建 的 网 页 可 以 由 模板 实现 批量 更 新 。 当 开发 者 修改 模板 页 后 ,可 以 选择 是 否 
同步 修改 所 有 的 相关 网 页 。 如 果 同 步 更 新 , 则 由 系统 自动 完成 针对 所 有 页 面 的 同步 更 新 。 

因此 ,对 于 使 用 模板 页 的 站 点 ,为 保护 以 模板 页 批量 更 新 网 页 的 优势 ,一 定 要 保护 好 模 
板 页 ,并 注意 不 要 改变 模板 页 中 可 编辑 区 域 的 名 称 。 


1.3.7 嵌入 式 框架 技术 


1. 什么 是 嵌入 式 框架 

嵌入 式 框架 技术 是 网 页 设计 中 用 于 解决 多 页 面 、 同 结构 问题 的 又 一 策略 。 其 基本 思路 
是 ,在 网 页 上 开辟 一 个 视窗 ,相对 固定 的 信息 可 以 直接 存放 在 页 面 上 ,而 变化 频繁 的 内 容 则 
由 视窗 实现 。 在 网 页 设计 技术 中 ,在 网 页 中 开辟 的 视窗 占据 网 页 中 的 一 个 区 域 , 称 为 嵌入 式 
框架 。 在 嵌入 式 框架 中 ,可 以 呈现 其 他 网 页 的 内 容 。 

嵌入 式 框架 是 框架 技术 的 一 个 改进 ,每 个 戏 入 式 框 架 都 有 一 个 名 称 。 该 名 称 可 作为 超 
链接 的 target 属性 的 值 ,表示 把 那个 超 链接 的 网 页 显示 在 这 个 嵌入 式 框架 内 。 
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2. 设计 嵌入 式 框架 
(1) 新 建 网 页 ,并 对 网 页 进行 布局 。 


(2) 选择 需要 频繁 更 新 数据 的 区 域 ,在 此 区 域 中 插入 说 入 式 框架 。 具 体 方法 是 : 


首先 ,切换 到 [代码 3 视图 。 
其 次 ,在 代码 状态 下 ,在 当前 位 置 插入 代码 : 


<iframe name = 名 称 width= 宽度 height = 高 度 src = 默认 网 页 名 ></iframe> 
就 会 在 当前 位 置 插入 一 个 嵌入 式 框架 。 


在 此 语句 中 ,嵌入 式 框架 的 高 度 和 宽度 可 使 用 当前 区 域 的 高 度 和 宽度 (如 使 用 此 框架 所 


在 单元 格 或 者 层 对 象 的 高 度 和 宽度 ) ,在 src 属性 中 可 指定 一 
件 名 ,用 于 作为 此 戏 入 式 框架 的 默认 信息 。 


一 个 网 页 文件 名 或 者 一 个 照片 文 


为 了 使 页 面 达到 和 谐 精 美的 效果 ,建议 以 Photoshop 技术 布局 的 页 面 为 基础 ,在 这 种 


页 面 中 插入 嵌入 式 框架 。 
3. 使 用 嵌 入 式 框架 


在 当前 网 页 中 ,可 对 某 些 文字 或 图 片 建立 超 链接 ,使 这 些 超 链接 的 target 一 舱 入 式 框架 
名 ”, 这 样 当 访问 者 单 击 这 些 超 链接 时 ,系统 会 自动 地 把 这 些 链接 对 象 显示 在 嵌入 式 框架 内 。 


笔者 的 教学 服务 平台 就 使 用 了 这 一 
个 嵌入 式 框架 ,而 左 侧 每 个 通知 的 超 链接 都 设置 其 target 属性 值 为 嵌 人 式 框 
架 名 。 因 此 , 当 学 生 单 击 左 侧 的 通知 时 ， 


统 说 明 "” 区 就 是 一 


技术 。 如 图 1-38 所 示 , 在 教学 服务 平台 中 ,中 部 的 “ 系 


马上 就 会 在 中 部 区 域 显示 出 该 条 信息 的 详细 内 容 。 


入 马 秀 解 教学 服务 平台 - Microsoft Inte 
文件 (E) 编辑 (E) 查看 收藏 他 ) 工具 (TD 珊 助 (0 


@ 雁 -. 卓 国 固 名 用 巡 灾 


地 址 人 D) [站 http://202, 112. 94. 39/nx1/ 
下 


rnet Ex 


tm 全 | 


plorer 


EE 号 区 
蔓 


司 回 # 引 biE ” 


ETEEEezaraeaezaEsnaereeza 


| 精品 课程 | 作者 向 介 | 
器 重要 通知 TT 
SE O111) pe 关于 近期 局 学 们 多 头 询问 的 问题 es a 
于 ( 才 育 介入 息 药 》 沁 1 (针对 C10JS] 斑 级 学 生 的 通知 ) 地 教育 管理 信息 系统 
| ) 去 计 短 机 必用 基 届 
{C10MNTS|2011, 01,06) 
0 A 和 霸 人 册 而 作 
玫 的 安 挂 (C10]5J12011.01.04) 全 和牛 的 9 是， 者， 并 0 到 忆 本 折扣 与 用 
关于 【计算 机 应 用 基础 】 网 络 实 此 通知 的 附件 中 。 请 参阅 附件 . 
坟 到 凡 
(C10JST|2010. 11.29) 
于 【计算 机 万 1 
的 说 明 
(oI .10) 3 天 扑  [ 电 双生 全 要 
关于 《多 汉人 汉 得 》 姑 未 二 wu.oL 1 
况 的 说 明 (nedjp|2010.07.02) OE 
和 (nedjp|2010.06. 28) ee 
关于 (多 媒 订 册页 》 源 程 风 未 若 | v 


生生 
将 


图 1-38 笔者 教学 服务 平台 的 散人 式 框架 
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1.4 客户 端 语言 JavaScript 
2 


1.4.1 JavaScript 的 特点 


JavaScript 是 一 种 可 以 嵌入 到 HTML 中 的 脚本 语言 , 它 基 于 Java 基本 语句 和 控制 流 ， 
以 Java 语言 作为 语法 基础 ,与 C 语言 的 语法 类 似 。 它 在 客户 端的 浏览 器 中 运行 ,在 执行 过 
程 中 被 浏览 器 逐 行 解释 执行 。 

JavaScript 的 语法 和 C 语言 相似 , 源 程序 中 区 分 字母 的 大 小 写 , 但 其 变量 不 事先 定义 也 
能 够 使 用 ,而 且 在 变量 赋值 时 不 进行 严格 的 数据 类 型 检查 ,因此 使 用 起 来 比 C 语言 灵活 。 

JavaScript 是 一 种 基于 对 象 的 语言 , 它 既 可 以 运行 系统 内 置 的 对 象 ,也 可 以 运用 自己 创 
建 的 对 象 来 实现 特殊 的 功能 。 

JavaScript 是 一 种 动态 性 的 语言 , 它 可 以 直接 对 用 户 的 输入 做 出 响应 ,无须 经 过 服务 
器 。 因 此 ,在 MIS 设计 中 , 它 经 常 被 用 作 输 入 数据 合法 性 的 初级 检测 .验证 用 户 是 否认 可 即 
将 执行 的 危险 操作 。 

JavaScript 采用 事件 驱动 机 制 来 实现 响应 ,只 依赖 浏览 器 本 身 ,与 操作 环境 无 关 。 


1.4.2 ”JavaScript 的 基本 语法 规则 


1. JavaScript 程序 段 的 标志 

JavaScript 语句 书写 在 “一 Script language 二 "JavaScript" 祖 过 /Script > 之 间 。 基 本 格 
式 为 : 

<Script language = "JavaScript"> 

JavaScript 语句 

</Script> 

由 于 JavaScript 语句 在 客户 端 执行 ,因此 对 于 任意 一 个 网 页 ,都 可 通过 浏览 器 的 【查看 源 文 
件 ] 功 能 ,看 到 该 网 页 中 的 JavaScript 代码 。 凡 是 位 于 “过 Script language 王 "JavaScript" 之 ”和 
“之 /Script 二 ”之 间 的 代码 都 是 JavaScript 代码 。 因 此 大 家 可 通过 这 一 特点 ,学 习 JavaScript 
语言 的 语法 规则 和 应 用 。 

2. JavaScript 语法 规则 

和 C 语言 相似 ,JavaScript 也 支持 程序 语言 的 三 种 基本 结构 。 由 于 它 以 C 语言 的 语法 
规则 为 基础 ,所 以 它 也 用 ”{) ?标记 一 个 程序 块 的 起 点 和 终点 ,而 且 在 语句 中 区 分 大 小 写字 
母 ,每 个 语句 都 以 英文 分 号 结束 。 注意,C 语言 体系 中 的 计 语 句 的 语法 规则 与 VB 有 较 大 差 
异 ,其 条 件 式 要 用 小 括号 括 起 来 ,而 且 没 有 关键 字 *Then”。 

1) JavaScript 分 支 结构 的 语法 规则 


a if( 条 件 式 ) 
(语句 体 ] 
本 或 者 : { 语句 体 } 


{ 语句 体 } 
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2) JavaScript 循环 结构 的 语法 规则 

for( 变 量 = 初 值 ; 变量 满足 条 件 式 ; 变量 ++) 或 者 : while (条 件 式 ) 
{ 循环 语句 } { 循环 语句 } 

3. JavaScript 的 常见 应 用 

1) 输出 语句 

Q@ 输出 数据 


document. writeln(" 输 出 的 信息 !!"); 

@ 发 出 警告 性 提示 

alert(" 提 示 信 息 "); 

2) 输入 语句 

变量 = prompt( 提 示 信息 ); 

本 语句 要 求 用 户 通 过 键盘 输入 信息 ,输入 的 信息 被 存储 到 变量 中 。 

变量 = confirnm( 提 示 信 息 ); 

本 语句 要 求 用 户 回答 Yes 或 No, 变 量 中 存储 的 是 用 户 选择 的 Yes 或 No。 在 MIS 设计 
中 通常 用 于 确认 用 户 的 操作 。 例 如 ， 

delit = confirm(" 您 确实 要 删除 这 个 文件 吗 ?")， 

3) 打开 窗口 

命令 格式 : 

window. open(" 要 显示 的 网 页 文件 名 称 ", "窗口 参数 设置 "); 

本 语句 常常 被 用 来 制作 弹出 窗口 ,在 弹出 窗口 中 显示 各 种 提示 信息 。 

例如 ,语句 “二 Body onload 二 "window. open('xxx. htm', ' 重 要 通告 ', 'scrollbars 二 no， 
resizable==no, toolbar 王 no; location 王 no，width 王 510，height=250") "过 ”表示 在 打开 当 
前 网 页 的 同时 打开 一 个 新 窗口 ,在 新 窗口 中 显示 网 页 文件 “xxx. htm” 的 内 容 。 

这 里 的 window 是 JavaScript 的 一 个 对 象 ,open 是 window 的 方法 , 指 新 打开 一 个 窗 
口 。 参 数 scrollbars 用 于 指定 是 否 保留 滚动 条 ; resizable 设置 是 否 可 以 调节 新 窗口 的 大 小 ; 
width 设置 新 窗口 的 宽度 ; height 设置 新 窗口 的 高 度 。 


4) 关闭 窗口 
命令 格式 : 


window. close( ); 


这 个 方法 常 被 用 来 关闭 当前 窗口 。 

例如 ,语句 “过 Input type 一 "Button" value 二 "关闭 窗口 " onclickk 二 "window. close()" 之 ” 
表示 当 单 击 此 按钮 时 ,会 自动 关闭 当前 窗口 。 

在 这 个 语句 中 ,用 “Input type 王 Button? 定 义 了 一 个 按钮 “关闭 窗口 ?。 当 此 按钮 被 单 击 
(onclick) 时 ,执行 JavaScript 对 象 window 的 close 方法 ,关闭 当前 窗口 。 
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1.4.3 JavaScript 语言 的 主要 应 用 


1. 实现 网 页 的 特殊 效果 

在 网 页 设计 中 ,以 JavaScript 设置 网 页 特殊 效果 是 应 用 最 频繁 的 技术 。 事 实 上 ,在 DW 
设计 网 页 过 程 中 ,所 有 的 行为 动画 、 在 页 面 上 跑 动 的 小 图 片 、 广 告 效 果 、 其 至 包括 显示 当前 日 
期 都 是 使 用 JavaScript 技术 实现 的 。 

例如 ,要 获取 当前 日 期 ,可 以 使 用 语句 “today 二 new Date();”, 这 里 的 today 是 用 户 自 
定义 的 变量 名 ; 若 要 显示 警示 性 的 信息 , 则 常常 使 用 语句 “alert(' 信 息 内 容 ');”。 

2. 设计 客户 端 交互 

JavaScript 语句 的 第 二 个 常见 用 途 是 设计 客户 端 交互 ,特别 是 在 用 户 要 执行 一 些 具有 
危险 性 的 动作 时 ,常常 利用 JavaScript 语句 设计 “确认 ”功能 。 例 如 ,用 户 单 击 了 “删除 ” 命 
令 ,就 可 以 提示 一 条 “您 确定 要 删除 吗 ?”, 当 用 户 应 答 为 Yes 时 才 真 正 执行 删除 操作 ,这 样 
可 以 避免 用 户 的 错误 操作 “Confirm( 询 问 信息 )? 就 是 通常 被 用 于 确认 用 户 操作 的 命令 。 

“变量 =prompt( 提 示 信 息 )” 常 被 用 于 获取 键盘 输入 信息 , 即 系统 以 弹出 窗口 的 形式 要 
求 用 户 输入 内 容 , 用 户 可 在 此 窗口 中 输入 数据 ,并 把 输入 结果 保存 到 变量 中 。 


1.4.4 JavaScript 应 用 示例 


JavaScript 的 应 用 非常 广泛 ,本 节 将 通过 几 个 案例 对 JavaScript 的 网 页 特效 功能 进行 简 
单 的 展示 。 由 于 JavaScript 应 用 的 优秀 案例 实在 是 数不胜数 ,因此 本 节 中 展示 的 几 个 案例 
权 当 抛砖引玉 。 

1, 设计 旋转 的 欢迎 字幕 

在 网 页 中 嵌入 如 图 1-39 所 示 的 代码 ,在 网 页 浏览 时 将 会 在 页 面 左 上 角 显 示 出 一 行 旋转 的 
文字 “欢迎 你 的 光临 >。 当然 ,也 可 以 修改 JavaScript 文档 中 的 文字 内 容 , 使 之 显示 其 他 信息 。 


划 js05. htn - 记事 本 
文件 (E) 编 加 (G) 格式 (0) 查看 (1) 帮助 (外 
《SCRIPT language=javascript> 
= 欢迎 你 的 光临 
"Widx=108; Decal=@.5; Mb=Phrase.length; y=-19800; 

For (x=0;xCNb;x++)€ 

Balises=Balises + “<DIV 1d=L* + x * * STYLE="width:3;font-fanily: Courier New;font-weight:bold;"; 

Balises=Balises +'position:absolute;top:40;left:50;2-index:0">* + Phrase-charht(x) + *</DIU>’; 


a 
docunent .write (Balises); Tine=window.setIinterval(“Alors()",198); 


Alpha=Alpha-1_Alpha; 
For (x=0;xCND;x++)¢ 
Alpha1=Alpha+Decal*x; Cosine=Math.cos(Alpha1); Ob=docunent.all("L"+x); 
ob .style-posLeft=Midx+*199sHath-sin(hlphat)*58; Ob.style.zindex=20*Cosine; 
Ob.style.fontSize=Taille*25*Cosine; 
Ob.style.color="rgb("+ (27+Cosinex88+58) + ","+ (127+Cosines80+58) + ",0)"; 


} 
《/script》 


1-39 设置 “旋转 字幕 "的 源 代码 
2. 设计 关闭 窗口 功能 
在 网 页 中 戏 入 如 图 1-40 所 示 的 代码 ,在 网 页 浏览 时 就 出 现 一 个 “关闭 窗口 "按钮 。 当 单 
击 此 按钮 时 ,当前 网 页 会 被 关闭 。 
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及 js06. txt - 记事 本 
文件 编 络 @) 格式 (0) 查看 (四 放 助 (了 


Kinput type=button value=" 【关闭 窗口 】" onclick="window.close()"> 


1-40 设置 “关闭 窗口 ”的 源 代码 


3. 设计 显示 当前 日 期 \ 时 间 功 能 
在 网 页 中 散人 入 如 图 1-41 所 示 的 代码 ,在 网 页 浏览 时 就 能 以 滚动 字幕 的 方式 显示 当前 的 
日 期 ,并 给 出 欢迎 信息 。 当 然 , 开 发 者 可 根据 自己 的 喜好 更 改 为 其 他 的 欢迎 词 。 


js07. htm - 记事 本 

文件 E) 编辑 ) 格式 (0) 查看 了 帮助 (8) 

Kscript language=JavaScript> 

today=new Date(); 

function initArray()¢ 
this.length=initArray.argunents.length 
for(uar i=0;i<this.length;i++) 
this[i+*1]=initArray.argunents[i] 


> 
var d=new initArray(" 星 期 日 "," 星 期 一 "," 星 期 二 "," 星 期 三 "," 星 期 四 "," 星 期 五 "," 星 期 六 "); 


document .wite( 
oa color=##908909 style="font-size:9pt;font-fanily: 宋体 >" 
today.getYear()," 年 "，today.getHMonth()+1," 月 "， today .getDate()," 日 
d[today .getDay()+1],"¢/font>¢/narquee>" ); 

/script> 


图 1-41 设置 当前 日 期 \ 时 间 的 源 代码 
4. 禁止 网 页 复制 .禁止 选择 .禁止 另存 为 
在 网 页 的 二 body 二 内 部 迭 入 如 图 1-42 所 指示 的 代码 ,被 浏览 的 网 页 将 不 能 被 他 人 复 
制 ,也 不 能 被 选择 和 另存 为 。 


区 js08[1] - 记事 本 
文件 (E) 编 轿 (E) 格式 (0) 下 看 (人 ”帮助 轩 


《body onselectstart="return false” oncopy="return false;” oncut="return false;" 
oncontextnenu="window.event .returnUalue=False”"> 


《noscript>Kifrane src=*.htnl>C/ifrane>C/noscript> 
< 


图 1-42 设置 禁止 复制 ,禁止 选择 和 禁止 男 存 为 的 源 代码 


在 图 1-42 中 ,位 于 所 body 二 内 部 的 “oncontextmenu 王 "window. event. returnValue 一 
false" ”命令 将 彻底 地 屏蔽 鼠标 右键 ,使 用 户 在 浏览 本 页 面 时 右 击 不 会 弹出 快捷 菜单 ; 语句 
“onselectstart 二 "return false"” 用 于 取消 选择 ,防止 复制 ; 语句 “onpaste 二 "return false"” 用 
于 不 准 粘贴 ; 语句 “oncopy 三 "return false;" oncut 二 "return false;"” 防 止 用 户 使 用 剪 切 和 
复制 功能 。 

语句 “table border oncontextmenu 一 return(false)” 可 用 于 针对 王 table 之 对 象 屏蔽 鼠标 
右键 。 

语句 “<noscript 盖 到 iframe src 一 * . html 记 之 /iframe 记 过 /noscript 这 ”使 得 当前 网 页 
不 能 被 “另存 为 ”, 可 以 防止 当前 页 面 被 他 人 存储 到 个 人 的 计算 机 中 。 

5. 设计 自动 设置 首页 .设置 收藏 来 

在 网 页 中 戏 入 如 图 1-43 所 示 的 代码 ,可 以 把 当前 网 页 设置 为 首页 ,并 可 以 添加 到 用 户 
的 收藏 夹 中 。 
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文件 (E) 编 颖 GE) 格式 (0) 查看 () 帮助 (四 


《input type=button ualue= 加 入 收藏 去 om 
“window.external .addFavorite("http:, 2 全 94.39/mx1" ," 马 秀 角 教学 服务 器 ");'> 


《input type=button walue= 设 置 为 首页 oncl 

pls .Soto ped er ser Honenesatey, ;this.setHonePpagel “http://282.112.94.39/nx1 );"> 
p> 

< 


图 1-43 设置 首页 ,收藏 夹 的 源 代码 


本 程序 提供 两 个 按钮 ,利用 按钮 的 单 击 事件 触发 设置 为 主页 "和 “加 入 收藏 夹 ”的 操作 。 
如 果 把 onclick 后 面 的 语句 放 在 二 body 记 的 onload 事件 后 , 则 会 自动 地 把 指定 的 网 址 添加 
到 访问 者 的 收藏 夹 , 或 者 设置 为 访问 者 浏览 器 的 主页 。 

注意 , 因 本 命令 操作 客户 机 的 浏览 器 , 带 有 本 命令 的 网 页 有 流 谍 软 件 的 嫌疑 ,因此 ,此 类 
网 页 可 能 会 被 各 类 防火 墙 和 杀毒 软件 拦截 。 


候 考 是 


1. 静态 网 页 的 文件 扩展 名 是 什么 ”以 什么 语言 编写 ? 

2. 网 页 中 的 对 象 (如 图 像 .图片 音乐) 通过 什么 方式 与 HTML 文档 发 生 联系 ?如何 才 
能 保证 在 复制 网 页 时 不 遗漏 相关 文档 ? 

3. 在 网 页 设计 中 ,主要 有 哪些 布局 方式 ? 各 有 什么 特点 ? 

4. 什么 是 嵌入 式 框架 ? 为 什么 要 使 用 嵌入 式 框架 ? 

5. 如 何 向 网 页 中 插入 滚动 字幕 ? 如 何 实现 垂直 滚动 字幕 效果 ? 

6. 如 何 实 现在 网 页 调 入 时 ,自动 打开 一 个 窗口 并 自动 呈现 指定 的 内 容 ? 

7. 如 何在 网 页 中 实现 小 图 片 在 整个 页 面 中 跑 动 的 效果 ,而 且 当 鼠 标 悬 停 在 小 图 片上 
时 ,小 图 片 暂停 跑 动 ? 

8. 如 何 向 网 页 中 插入 “ 当 鼠 标 经 过 时 自动 切换 图 片 ” 的 效果 ? 

9. 什么 是 CSS 文档 ? 如 何 设置 “ 当 和 鼠标 经 过 超 链接 时 , 超 链接 的 外 观 会 发 生变 化 ” 
的 效果 ? 

10. 为 什么 要 使 用 Photoshop 实施 网 页 布局 ? 如 何 才能 利用 Photoshop 实现 DIV 十 
CSS 布局 方式 ? 

11. 什么 是 JavaScript? 在 网 页 设计 中 ,JavaScript 有 什么 作用 ? 

12. 如 何在 网 页 中 实现 弹出 警示 框 效果 ? 


仁 机 实 训 是 


充分 发 挥 自己 的 主观 能 动 性 和 艺术 天 赋 ,编写 一 个 个 人 介绍 性 质 的 网 络 主页 ,要 求实 现 
以 下 目标 。 

(1) 网 页 以 Photoshop 实施 布局 ,使 用 DIV 十 CSS 布局 方式 ,网 页 不 少 于 6 个 HTML 
文件 。 
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(3) 向 页 面 中 插入 表格 。 

(4) 实现 以 表格 显示 信息 表格 精确 定位 ,包括 设置 单元 格 边框 .设置 表格 背景 的 功能 。 

(5) 网 页 中 包含 超 链接 ,能 够 链接 到 特定 的 HTML 文件 ,特定 的 网 站 和 链接 Email 
地 址 。 

(6) 网 页 中 包含 滚动 字幕 。 

(7) 实现 一 些 网 页 特效 ,例如 在 页 面 上 跑 动 的 小 图 标 , 当 单 击 小 图 标 时 会 自动 链接 到 特 
定 的 网 页 。 

(8) 在 网 页 调和 人 时 ,有 弹出 窗口 。 

(9) 网 页 中 包含 嵌入 的 Flash 小 动画 。 

注意 : 所 有 HTML 文件 的 文件 名 由 不 包含 空格 的 英文 字母 组 成 ,首页 文件 名 为 


index. htm。 


ASP.NET 开 发 基础 


学 习 要 点 

本 章 主要 学 习 ASP.NET 的 环境 与 C# 语 法 基础 ,要 求 了 解 VS2008 环境 的 安装 与 配 
置 \ 面 向 对 象 的 程序 设计 思想 与 相关 概念 .C# 语 言 的 基本 语法 结构 .ASP .NET 项 目的 结 
构 。 本 章 重 点 关注 以 下 内 容 : 

。 ASPX 与 ASPX. CS 文档 的 结构 。 

。 C# 的 数据 类 型 .运算 符 。 

。 C# 的 语句 形式 与 方法 体 (函数 ) 的 结构 。 

。 String 类 的 定义 与 数据 类 型 转换 。 


@.1 ASP.NET 基础 知识 
\ 


2.1.1 什么 是 ASP.NET 


ASP.NET 是 当前 开发 动态 网 站 、 设 计 动 态 网 页 的 一 种 计算 机 技术 ,这 种 技术 基于 
.NET Framework 框架 ,能 够 便利 \ 快 捷 地 完成 各 种 动态 网 站 的 开发 ,对 基于 B/S 结构 的 信 
息 系 统 开发 提供 了 全 面 的 支持 。 

1. .NET Framework 概述 

.NET Framework 是 一 套 微软 公司 提供 的 应 用 程序 开发 框架 ,其 目的 是 为 开发 者 提供 
一 个 一 致 的 开发 模型 。 目 前 微软 公司 的 高 级 语言 程序 设计 技术 都 建立 在 这 个 框架 的 基 
础 上 。 

Microsoft 发 布 了 多 个 版 本 的 .NET Framework ,目前 最 新 的 版 本 是 .NET Framework 
4.0。Visual Studio 2008 是 一 种 常用 的 .NET 系列 开发 工具 , 它 基 于 .NET Framework 3. 5， 
可 以 无 缝 地 运行 在 Windows 系列 服务 器 和 客户 机 上 ,是 当前 程序 开发 的 主流 技术 之 一 。 

.NET Framework 主要 由 两 个 组 件 构成 : 其 一 是 公共 语言 运行 库 (Common Language 
Runtime,CLR) ,也 称 为 公共 语言 运行 时 ; 其 二 是 .NET Framework 的 类 库 。 

CLR 可 以 被 看 做 一 个 在 执行 程序 时 管理 代码 的 代理 ,提供 诸如 内 存 管理 、 线 程 管 理 和 
远程 处 理 等 核心 服务 ,而 且 还 强制 实施 严格 的 类 型 管理 以 及 确保 系统 安全 性 和 可 靠 性 的 控 
制 机 制 。 可 以 说 ,CLR 为 终端 程序 提供 了 一 个 运行 的 平台 ,使 得 凡是 符合 公共 语言 规范 的 
程序 语句 都 可 以 在 任何 安装 有 CLR 的 操作 系统 中 运行 , 极 大 地 简化 了 程序 开发 ,提升 了 开 
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发 效率 。 也 正 是 由 于 这 一 原因 ,基于 CLR 开发 的 程序 基本 脱离 了 面向 硬件 的 开发 ,这 种 程 
序 生成 的 EXE 文件 或 DLL 文件 并 不 是 可 被 CPU 直接 执行 的 机 器 代码 ,而 是 一 种 基于 
CLR 的 中 间 语 言 。 即 基于 CLR 开发 的 程序 即便 是 已 经 编译 为 EXE 文件 ,也 只 能 运行 在 已 
经 安装 CLR 的 计算 机 平台 上 。 

Microsoft .NET Framework 类 库 是 一 个 由 Microsoft .NET Framework SDK 中 包含 的 
类 ,接口 和 值 类 型 组 成 的 库 , 该 库 为 开发 者 提供 对 系统 功能 的 访问 ,是 建立 Microsoft. NET 
Framework 应 用 程序 ,组 件 和 控件 的 基础 。 

2. ASP. NET 语言 概述 

ASP 语言 是 微软 公司 于 1996 年 推出 的 动态 网 站 开发 语言 ,在 本 世纪 初 曾经 非常 流行 。 
即使 当前 ,也 仍 有 大 量 的 B/S 结构 的 信息 系统 在 应 用 ASP 提供 的 开发 技术 。 然 而 ,由 于 
ASP 技术 允许 在 HTML 文档 的 任意 位 置 随意 地 嵌入 ASP 语句 ,这 一 策略 在 为 初学 者 提供 
便利 的 同时 ,也 会 因为 ASP 代码 与 网 页 界面 控制 符号 混合 在 一 起 而 导致 代码 可 读 性 差 ,性 
能 不 易 扩 充 等 缺陷 ,更 不 符合 主流 的 程序 设计 思想 。 

对 于 ASP 的 上 述 缺陷 ,其 技术 提供 者 心 知 肚 明 , 早 在 ASP 刚刚 面世 的 第 2 年 (1997 
年 ) ,IIS 的 开发 人 员 就 提出 了 ASP.NET 的 技术 设想 。ASP.NET 彻底 抛弃 了 脚本 语言 ,而 
代 之 以 编译 型 语言 。 目 前 ,ASP .NET 框架 可 以 兼容 多 种 开发 语言 (Visual Basic`C++ 和 
C# 等 ), 由 于 这 些 语言 都 调用 统一 的 .NET Framework 框架 ,使 用 相同 的 类 库 , 所 以 其 程序 
开发 过 程 仅 有 语法 上 的 少量 差异 ,其 设计 思路 和 调用 类 库 的 方法 非常 相似 。 

ASP.NET 的 开发 实质 上 是 一 种 面向 对 象 的 程序 设计 ,与 ASP 执行 脚本 的 思想 完全 不 
同 , 它 提供 了 对 事件 驱动 机 制 的 全 面 支持 ,而 且 把 网 页 内 容 和 ASP.NET 的 专用 语句 进行 了 
适当 分 离 ,使 它们 既 有 机 地 结合 在 同一 个 体系 下 ,又 可 分 处 于 不 同 的 文件 中 ,为 界面 设计 与 
代码 设计 的 分 工 合作 提供 了 可 能 ,完全 符合 主流 的 程序 设计 理念 。 

3. ASP.NET 开发 环境 

ASP.NET 系列 是 Microsoft 公司 的 产品 ,与 Windows 系列 操作 系统 有 很 好 的 兼容 性 ， 
其 主要 开发 工具 就 是 Microsoft Visual Studio 系列 工具 ,常见 的 版 本 有 三 个 : 基于 .NET 
Framework 1. 1 的 Visual Studio 2003 ,基于 .NET Framework 2.0 的 Visual Studio 2005， 
基于 .NET Framework 3. 5 的 Visual Studio 2008。 另 外 ,基于 .NET Framework 4.0 的 
Visual Studio 2010 也 已 面世 。 


2.1.2 VS2008 简介 


1. 什么 是 VS2008 

VS2008 就 是 Visual Studio 2008 ,是 Microsoft 为 .NET 系列 程序 开发 提供 的 开发 环 
境 。VS2008 提供 了 一 套 完整 的 开发 工具 ,用 于 生成 ASP.NET Web 应 用 程序 .XML Web 
服务 .桌面 应 用 程序 和 移动 应 用 程序 等 。 

在 VS2008 下 ,系统 提供 了 三 种 开发 语言 : Visual Basic.C# 和 C++。 开 发 者 可 以 根据 
自己 的 开发 习惯 选择 适当 的 语言 。 另 外 ,由 于 三 种 语言 使 用 共同 的 集成 开发 环境 、 使 用 相同 
的 类 库 , 因 此 开发 者 可 以 便利 地 实现 工具 共享 ,可 以 轻松 地 创建 混合 语言 解决 方案 ,可 以 便 
利 地 从 一 种 语言 迁移 到 另外 一 种 语言 。 

VS2008 内 置 了 Web 服务 器 组 件 ,使 得 开发 者 可 以 不 必 专 门 安装 Web 服务 器 就 可 以 实 
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现 Web 类 程序 的 开发 与 调试 。 

2. 安装 VS2008 

由 于 是 Microsoft 系列 的 产品 ,能 够 与 Windows 无 颖 集成 ,因此 其 安装 非常 简单 。 

1) 启动 安装 过 程 

把 Visual Studio.NET 2008 光盘 放 到 光驱 ,双击 其 中 的 Setup. exe 程序 启动 安装 过 程 。 

注意 : 如 果 获 得 的 软件 是 单一 的 压缩 文件 , 则 需要 先 运行 解压 缩 程序 ,把 此 压缩 文件 释 
放 到 一 个 空闲 空间 较 大 的 磁盘 上 ,然后 再 执行 setup. exe 程序 。 

2) 安装 过 程 

安装 程序 首先 进入 如 下 图 2-1 所 示 的 界面 。 


Ye Visual Studio 


(办 时 aaal Studi6 2006 功能 。 也 


msdn, 本 En Liray 功能 多 也 可 以 即 
NSDN Librarys 
对 Ms 和 ss， 确保 isau Stadio 2008 


ER 


图 2-1 VS2008 安装 界面 


首先 单 击 [ 安 装 Visual Studio 2008】 选 项 ,启动 安装 项 目 。 系 统 首先 进行 自 检 。 

系统 自 检 完毕 ,要 求 用 户 认 可 软件 使 用 协议 ,选中 [同意 ] 单 选 按钮 后 ,在 [产品 密 钥 ] 框 
中 输入 产品 密 钥 ,然后 单 击 【 继 续 ] 按 钮 ,开始 启动 自动 安装 过 程 。 

系统 将 弹出 [组 件 选择 ] 对 话 框 。 此 时 用 户 可 选择 安装 哪些 组 件 。 设 置 完 成 后 , 单 击 【 立 
即 安装 按钮 。 系 统 启动 文件 验证 与 复制 过 程 。 

安装 完毕 ,系统 再 次 返回 到 如 图 2-1 所 示 的 界面 下 ,此 时 第 二 项 成 为 高 亮 显 示 。 如 果 当 
前 没有 MSDN 文档 资料 (系统 的 帮助 文档 ) ,可 直接 选择 [退出 ] 按 钮 结束 安装 过 程 。 否 则 单 
击 高 亮 显 示 的 [3 产品 文档 】 为 系统 安装 完整 的 帮助 文档 。 

注意 ; 由 于 VS2008 非常 庞大 ,原始 安装 文件 有 4GB 多 ,安装 文件 达 6GB 以 上 。 因 此 
计划 安装 VS2008 的 计算 机 应 该 具备 较 好 的 性 能 ,而 且 硬盘 上 要 有 充足 的 空闲 空间 。 

默认 情况 下 ,为 便于 ASP.NET 开发 ,VS2008 的 安装 系统 自动 为 用 户 安装 了 一 套 精 简 版 
的 SQL Server 2005 数据 库 管理 系统 ,可 以 通过 VS2008 的 服务 器 管理 器 实现 数据 库 操作 。 

3. 启动 VS2008 

选择 开始 菜单 [开始]>【 所 有 程序 】->Microsoft Visual Studio 2008 一 Microsoft Visual 
Studio 2008 即 可 启动 这 个 系统 ,最 初 的 界面 如 图 2-2 所 示 。 

注意 : 建议 用 右键 把 [开始 】 菜 单 中 的 VS2008 启动 程序 的 快捷 方式 复制 到 桌面 上 ,以 
便 直接 双击 桌面 上 的 快捷 方式 启动 VS2008。 
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:了解 福 型 
严 ?在世 教程 中 ，Stephen Wakher 和 向 和 介绍 ASP.NI 
应 用 人 学 的 不 同 部 分 


了 角 闪 制品 、 近 制 器 深 作 和 近 作 结果 (Visual Basic 彼得 
FL 4 Dec 2009 03:00:00 GMT - 在 李 教 得 中 ，Stephel 
Wakther 将 向 您 介绍 ASPJNET MVC 控制 芒 ， 您 棕 了 名 ! 
靳 的 控制 器 并 过目 不 同 关 型 的 报 人 结果 


Tm Rn TA Molnerrvieosl Reir 电 


图 2-2 VS2008 的 初始 界面 


首次 启动 VS2008 ,系统 要 求 用 户 选 择 开发 语言 ,本 课程 选择 C# 作为 默认 的 开发 语言 。 
选择 菜单 [文件 ]>【 新 建 >【 项 目 】, 即 可 打开 [新 建 项 目 ] 对 话 框 ,如 图 2-3 所 示 。 此 时 


可 以 开始 新 系统 的 创建 。 
[一 一 一 
于 
项 目 类 型 [): 模板 中 : NET framework 35 “回回 

4 Visual ce “| Visual sudio 已 安 雪 的 模 株 
Windows 一 ASPNET Web 应 后 @ 序 
Web 易 ASP NET Web 服务 应 用 全 六 
一 Asp NET AJAX 服务 器 近 件 
en 引 加 AspNET AJAX 服务 器 注 件 扩展 导 序 
Ri 蜀 AspNET sa 
Wer 醒 wcF 服务 详 及 他 
Workflow 我 的 模板 
Wt 国 冯 二 机 模 反 

其 人 语言 


用 于 创建 内 有 Web 用 户 界面 的 应 用 程序 的 项 目 (NET Framework 3.5) 


匀称 IN): MyTest 
EU: -| WS). 
解决 方 时 名 称 IM):，。 WebAppiicationl 同人 建 科 方 妆 的 目录 ([D) 

(ae 


2-3 新建 VS2008 项 目 


从 左 侧 的 [项 目 类 型 ] 中 选择 Web, 然 后 从 右边 的 模板 中 选择 [ASP .NET Web 应 用 程 
序 】, 在 底部 的 [名 称 ] 文 本 框 中 为 本 项 目 命名 为 MyTest, 在 [位置] 下拉 列 表 框 中 选择 项 目 
的 存储 位 置 G:\VsTest, 最 后 单 击 【 确 定 ] 按 钮 , 则 系统 自动 创建 一 个 名 称 为 MyTest 的 项 
目 , 自 动 打 开 一 个 名 字 为 Default. aspx 的 动态 网 页 ,并 进入 到 项 目 设计 状态 ,如 图 2-4 所 示 。 
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2-4 VS2008 项 目的 默认 设计 页 面 


4. VS2008 设计 界面 

如 图 2-4 所 示 ,VS2008 的 设计 界面 由 菜单 栏 .工具 栏 . 主 工作 区 和 右 侧 的 面板 几 个 区 域 
构成 。 由 于 VS2008 的 功能 非常 强大 ,不 可 能 在 界面 上 直接 显示 所 有 功能 ,所 以 很 多 面板 都 
处 于 隐藏 状态 。 从 开发 者 的 视角 来 看 ,用 到 的 主要 功能 有 以 下 几 个 。 

1) 工具 箱 

单 击 窗口 左 侧 的 [工具 箱 ] 按 钮 ,可 以 展开 [工具 箱 ] 面 板 。 在 【工具 箱 ] 面 板 中 按照 类 别 
内 置 了 许多 控件 。 开 发 者 可 从 工具 箱 中 直接 拖 动 控件 到 主 工作 区 中 。 如 果 窗 口 左 侧 没有 
【工具 箱 ] 按 钮 , 则 可 以 利用 系统 菜单 [视图 ]->【 工 具 箱 ] 打 开 【 工 具 箱 ] 面 板 ,如 图 2-5 所 示 。 


四 ESalaiei 
加 篇 S 方 宾 “MyTest" (1 个 项 目 ) 


2-5 VS2008 的 工具 箱 和 解决 方案 资源 管理 器 


47 


48 


NM 


动态 网 站 设计 与 开发 (ASP. NET 版 ) 


2) 解决 方案 资源 管理 器 

设计 窗口 右 侧 是 [解决 方案 资源 管理 器 ] 面 板 , 以 树 状 结构 的 形式 列 出 了 本 项 目 中 涉及 
的 资源 : 其 中 “引用 ”下 包含 着 本 项 目 要 引用 的 其 他 资源 ,“App_Data” 下 是 本 项 目 要 用 到 的 
数据 库 文件 ,Default. aspx 是 本 项 目 默认 的 首 个 动态 网 页 文件 ,web. config 文件 是 这 个 项 目 
的 配置 文件 。 开 发 者 可 以 通过 【解决 方案 资源 管理 器 】 面 板 添加 或 删除 项 目 中 的 某 个 资源 ， 
进行 资源 管理 。 

如 果 窗口 右 侧 没有 【解决 方案 资源 管理 器 了 面板 , 则 可 以 利用 系统 菜单 [视图 】 并 解决 方 
案 资源 管理 器 打开 【解决 方案 资源 管理 器 】 面 板 。 


一 一 一 3)【 属 性 面板 
Tanaon SamwebutyebcontokT > 设计 窗口 的 右 下 角 是 【属性 面板 ,如 图 2-6 所 示 。 当 
有 -| 开发 者 选 定 主 窗口 中 的 某 个 对 象 时 【属性 ] 面 板 中 将 显示 
Es 引 ”出 该 对 象 在 各 个 属性 上 的 取 值 。 通 过 [属性 ] 面 板 ,开发 者 
:Ce -| ”还 可 以 为 对 象 设置 对 应 的 方法 程序 。 图 2-6 内 两 个 被 用 
i 圆 环 标记 的 按钮 中 , 左 侧 的 按钮 为 [属性 ] 按 钮 , 右 侧 的 按 

钮 为 [方法 ] 按 钮 。 
图 2-6 VS2008 的 【属性 界面 如 果 屏 幕 上 没有 【属性 面板 ,可 以 通过 系统 菜单 【 视 
图 】- 江 属性 窗口 命令 打开 。 


4) 服务 器 资源 管理 器 

利用 “服务 器 资源 管理 器 "可 以 完成 打开 数据 库 连 接 、 在 SQL Server 中 创建 数据 库 、 显 
示 数 据 库 和 系统 服务 等 操作 。 如 果 将 服务 器 资源 管理 器 中 的 节点 直接 拖 动 到 主 工作 区 中 ， 
就 可 以 在 当前 项 目 中 直接 引用 数据 资源 或 者 建立 监视 数据 库 内 容 的 管理 组 件 。 

服务 器 资源 管理 器 默认 显示 在 VS2008 设计 界面 的 左上 部 。 如 果 窗 口 左 上 部 没有 服务 
融资 源 管理 器 ,也 可 以 利用 系统 菜单 [视图]>【 服 务 器 资源 管理 器 ] 打 开 【 服 务 器 资源 管理 
器 了 面板。 

5. VS2008 配置 

为 了 适应 开发 者 的 个 人 习惯 ,开发 者 可 以 按照 自己 的 需求 对 VS2008 的 开发 环境 进行 
配置 。 改 变 VS2008 配置 的 方法 是 : 单 击 系统 菜 单 [ 工 具 】>【 选 项 】 ,打开 [选项 ] 对 话 框 ( 见 
图 2-7) ,然后 进行 配置 。 

常见 的 配置 主要 包括 以 下 3 个 方面 。 

1) 设置 系统 提供 帮助 的 方式 

对 于 学 习 者 来 讲 , 应 用 系统 提供 的 帮助 功能 给 予 编程 指导 是 常见 的 方法 。 如 果 在 安装 
VS2008 时 已 经 安装 了 其 帮助 系统 MSDN, 则 可 以 配置 系统 为 【 仅 在 本 地 尝试 ,而 不 联机 尝 
试 】, 如果 使 用 此 设置 , 当 开发 者 寻求 帮助 时 ,VS2008 将 只 在 本 地 的 MSDN 中 查找 帮助 
信息 。 

2) 设置 编辑 器 的 字体 .字号 和 颜色 

开发 者 可 以 通过 图 2-7 左 侧 的 “字体 和 颜色 ?项 打开 【字体 窗口 ,对 编辑 器 使 用 的 字体 、 
字号 .颜色 进行 设置 ,以 适应 开发 者 的 编程 习惯 。 

3) 为 代码 添加 行 号 

在 程序 开发 过 程 中 出 现 语法 错误 是 难免 的 ,而 系统 通常 利用 行 号 标记 出 出 错 的 位 置 。 
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为 了 方便 开发 者 快速 地 定位 到 出 错位 置 ,可 以 在 [文本 编辑 器 下 所 有 语言 I 下 的 [常规] 界面 
中 ,设置 编辑 器 面板 “显示 行 号 ”。 


| 


团 MSDN Online 
园 Codezone 社 区 
加 
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图 2-7 对 VS2008 进行 配置 


2.1.3 两 个 简单 的 ASP.NET 程序 


1. 利用 ASP .NET 制作 简单 的 计算 器 

设置 如 图 2-8 所 示 的 计算 器 程序 。 要 求 : 当 在 【第 一 个 数据 : 3] 和 【第 二 个 数据 : 】 后 输 
入 数值 后 , 单 击 [ 十 3 则 在 [结果 3 后 的 文本 框 中 显示 出 两 数 之 和 , 单 击 [ 一 ] 则 在 [结果 3 后 的 文 
本 框 中 输出 两 数 之 差 。 

1) 新 建 动态 网 页 文件 

右 击 【解决 方案 资源 管理 器 ] 面 板 中 的 项 目 名称 
MyTest, 在 弹出 的 快捷 菜单 中 选择 [添加 】>【 新 建 | 。 于- 证 
项 】 ,系统 将 随后 弹出 一 个 【添加 新 项 ] 对 话 框 。 六 训 

在 对 话 框 中 选择 [Web 窗 体 】, 然 后 输入 窗 体 的 i L 
名 称 "Yunsuanqi”, 最 后 单 击 【 添 加 按钮 。 此 时 将 有 | reeretE 而 - Rigw 
一 个 新 的 动态 网 页 文件 Yunsuanqi. aspx 被 添加 到 
【解决 方案 资源 管理 器 面板 中 。 国生 生 条 系 各 的 和 

2) 向 动态 网 页 中 添加 控件 

动态 网 页 “Yunsuanqi” 被 添加 后 ,会 自动 在 主 工作 区 打开 ,并 在 工作 区 的 顶部 有 一 个 虚 
框 。 这 个 虚 框 就 是 该 动态 网 页 的 信息 区 域 。 

首先 在 虚 框 中 输入 文字 “第 一 个 数据 :”, 然 后 从 【工具 箱 ] 的 [标准] 类 工具 下 拖 动 
TextBox 控件 (文本 框 控件 ) 到 “第 一 个 数据 :” 后 面 。 

按 Enter 键 ,光标 进入 下 一 行 ,输入 文字 “第 二 个 数据 :”, 然 后 再 从 [工具 箱 ] 中 拖 动 一 个 
TextBox 控件 放 到 “第 二 个 数据 .” 后 面 。 

同 理 , 输 入 文字 “结果 :”, 并 放置 “结果 ”后 面 的 文本 框 。 
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最 后 ,两 次 从 [工具 箱 ] 的 [标准] 类 工具 下 拖 动 Button 控件 (按钮 ) 到 “结果 ”下 面 的 一 
行 中 。 
注意 : 上 述 所 有 控件 都 必须 放置 在 工作 区 的 虚 框 中 ( 即 内 置 的 之 form 记 与 <</form 放 
之 间 )。 

3) 修改 各 个 控件 的 属性 

选中 第 一 个 文本 框 ,在 右 下 角 的 【属性 了 面板 中 找到 这 个 控件 的 ID, 把 其 ID 修改 为 T1; 
同 理 把 第 2 个 文本 框 的 ID 修改 为 T2; 第 三 个 文本 框 的 ID 修改 为 TT。 

选中 第 一 个 按钮 ,在 右 下 角 的 【属性 了 面板 中 找到 这 个 按钮 的 ID, 把 其 ID 修改 为 jia, 把 
Text 属性 修改 为 【十 】; 再 选中 第 2 个 按钮 ,通过 【属性 ] 面 板 修 改 其 ID 为 “jian”, 其 Text 属 
性 为 [一 】。 

4) 为 按钮 添加 C# 代 码 

用 鼠标 双击 按钮 [十 】, 此 时 系统 自动 创建 一 个 yunsuanqi. aspx. cs 文件 ,并 把 此 文件 显 
示 在 主 工作 区 中 ,如 图 2-9 所 示 。 


文件 昌 ”篇 纺 (E) ”视图 (V) 本 攀 (R) 项目 P) 生成 @) 涯 (D) 工具 D 测 坛 9 音 DW 
帮助 (H) 

Ba. 二 

加 加 和 和 | 这 这 | 三 2 日 男 对 加 有 

[TE Tx) Yunsuanqiaspes [yunsuangiaspe | Defoultaspucss] =X rx| 
Ba YMyTestyunsuanai » $9jia_Click(object sender, Event ~ 5 


I vine System Yeb UI VebControls WP 
此 有 中兴 有 可 12| EE Systen Yal. Ling; 
13 


理 
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Systen Web UL, Pace | [ 
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2-9 动态 网 页 的 CS 程序 的 初始 结构 


从 图 2-9 可 知 , 对 于 动态 网 页 “yunsuanqi”, 系 统 自动 产生 了 一 个 名 字 为 yunsuanqi. 
aspx. cs 的 文件 ,该 文件 用 于 存放 全 部 C# 代 码 。 
在 上 述 代码 中 有 两 行 语句 ( 见 图 2-10)。 


| Brotected void jia Click(object sender, Eventhrzs 5 


2-10 ”jia 按钮 的 Click 事件 的 对 应 方法 的 框架 


光标 停 在 这 两 行 语句 的 一 对 {} 之 间 。 从 语句 的 格式 可 以 知道 : 这 是 一 个 C 语言 的 函 
数 ,函数 名 称 为 jia_Click, 即 这 个 函数 是 用 于 处 理 【 十 】 按 钮 的 单 击 (Click) 事 件 的 ,也 就 是 
说 ,设计 者 可 以 把 单 击 按钮 [十 ] 时 要 执行 的 代码 写 在 这 里 。 

本 例 中 ,希望 单 击 按钮 [十 ] 时 自动 取出 文本 框 Tl 和 T2 的 输入 内 容 , 把 输入 内 容 分 别 
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变 成 整 型 量 后 相 加 ,然后 把 其 "和 ? 值 转化 为 字符 串 后 存放 到 TT 文本 框 中 。 对 应 的 语句 如 
图 2-11 所 示 。 


22i protected vold ]1a_C11ck(object sender, Eventhres e. 


24d: int xx = Corvert.ToInt32(T1. Text) + Convert. ToInt32(T2. Text) ; 
25 TT. Text = xx.ToString () ; 
26 } 


图 2-11 jia 按 钮 的 Click 事件 的 对 应 的 代码 


同 理 , 单 击 主 工作 区 顶部 的 yunsuanqi. aspx 标签 , 回 到 设计 视图 ,双击 按钮 [一 】, 系统 
又 自动 回 到 yunsuanqi. aspx. cs 的 编码 状态 下 ,并 增加 了 一 个 函数 jian_Click。 然 后 为 此 函 
数 添加 代码 ,其 代码 如 图 2-12 所 示 。 


protected vold Jian Click(object sender, Eventhrgs e 
{ 


int xx = Convert, ToInt32(T1. Text) - Convert,ToInt32(T2.Text) ; 
TT. Text = xx.ToString () : 


} 
2-12 jian 按钮 的 Click 事件 的 对 应 的 代码 


5) 保存 并 测试 

按 快捷 键 Ctrl 十 S 保存 文件 。 

选择 系统 菜单 [文件 】- 江 在 浏览 器 中 预览 】, 系 统 将 启动 浏览 器 ,在 其 中 显示 动态 网 页 
yunsuanqi 的 内 容 。 


此 时 ,可 以 输入 一 些 整 数 ,然后 分 别 单 击 [十 J 和 一] 按钮 ,观察 程序 的 运行 效果 。 
2. 利用 ASP. NET 制作 简单 的 测试 题 程序 = 1 
设计 如 图 2-13 所 示 的 动态 网 页 ,在 用 户 | | 
浏览 网 页 时 ,系统 给 出 题目 ,并 根据 答题 情况 | oa zs 
给 出 成 绩 。 如 果 成 绩 为 100 分 , 则 提示 "大 棒 |‖ ，。 二 


了 ! Great!l”, 如 果 在 70~100 之 间 , 则 提示 为 太阳 从 哪里 升 起 ，[ 计 方 
“很 好 ,不 错 嘛 1”, 如 果 高 于 30 分 低 于 70 分 ， 


机 您 的 成 绩 是 , 100 ”| 太 棱 了 ! Greall 
则 提示 为 “有 差距 , 尚 需 努力 !"。 如 果 低 于 30 
分 , 则 提示 “您 与 要 求 相差 较 多 ,请 努力 呀 1”。 @ intemet | Nazt: BA 而 lO0% 
1) 新 建 动 态 网 页 文件 图 2-13 设计 测试 题目 


右 击 【解决 方案 资源 管理 器 】 面 板 中 的 项 
目 名 称 MyTest, 在 弹出 的 快捷 菜单 中 选择 [添加 】->【 新 建 项 】, 系统 将 随 之 弹出 一 个 【添加 
新 项 对话 框 。 

在 对 话 框 中 选择 “Web 窗 体 ”, 然 后 输入 窗 体 的 名 称 “ceshi”, 单 击 对 话 框 底部 的 按钮 
【添加 】。 此 时 将 有 一 个 新 的 动态 网 页 文件 ceshi. aspx 被 添加 到 【解决 方案 资源 管理 器 】 面 
板 中 。 

2) 向 动态 网 页 中 添加 控件 

动态 网 页 ceshi” 被 添加 后 ,会 自动 在 主 工作 区 打开 ,并 在 工作 区 的 顶部 有 一 个 虚 框 。 
这 是 一 个 默认 的 “< DIV></DIV>> ?对 象 ,位 于 “一 form runat 二 server 祖 过/form 放 ”之 间 ， 
动态 网 页 的 所 有 内 容 都 要 放 在 此 对 象 之 中 。 下 面 对 新 窗 体 进行 如 下 操作 。 
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@ 在 虚 框 中 输入 文字 “测试 题 :”, 然 后 利用 菜单 [格式 】>【 字 体 ] 设 置 测试 题 的 字形 、 
字号 。 

@ 按 Enter 键 后 ,光标 进入 下 一 行 ,接着 在 下 一 行 输 入 文字 “中 国 的 首都 是 :”, 然 后 从 
【工具 箱 ] 的 [标准 ] 栏 目下 拖 动 TextBox 控件 (文本 框 控件 ) 到 “中 国 的 首都 是 :” 后 面 。 

@ 在 下 一 行 输入 文字 “101 十 5 二 :”, 然 后 再 从 工具 箱 中 拖 动 一 个 TextBox 控件 放 到 它 
的 后 面 。 

@@ 再 在 下 一 行 输入 文字 “太阳 从 哪里 升 起 :” 然 后 再 从 工具 箱 中 拖 动 一 个 
DropDownList( 下 拉 式 列表 框 ) 控 件 放 到 它 的 后 面 。 

同 理 , 输 入 文字 “您 的 成 绩 是 :”, 然 后 分 别 从 工具 箱 中 拖 动 1 个 TextBox 控件 和 1 个 
Label 控件 放 到 它 的 后 面 。 

@ 从 [工具 箱 ] 的 [标准 栏目 下 拖 动 一 个 Button 控件 (按钮 ) 到 DropDownList 控件 
后 面 。 

3) 修改 各 个 控件 的 属性 

选中 第 一 个 文本 框 ,在 右 下 角 的 【属性 了 面板 中 找到 这 个 控件 的 ID, 把 其 ID 修改 为 T1; 
同 理 把 第 2 个 文本 框 的 ID 修改 为 T2 ,成 绩 对 应 的 文本 框 的 ID 修改 为 Sco。 

选中 唯一 的 DropDownList 控件 ,从 [属性 了 面板 中 找到 其 ID 属性 ,修改 为 T3; 接着 , 单 
击 此 控件 右上 角 的 “二 ”标记 (智能 按钮 ) ,选择 【编辑 项 】, 则 打开 一 个 设置 下 拉 式 列表 框 选 项 
的 对 话 框 一 一 【ListItem 集合 编辑 器 】, 如 图 2-14 所 示 。 


成 员 (M).: 天 访 必 性 人: 
GE 国外 
上 着 日 瑞 
团 | enabed Tme 

Selected False 

Text 西方 

Value 西方 
[Lam | 

Cm |] 


图 2-14 设计 DropDownList 的 选项 


从 左 侧 单 击 按钮 [添加 】 ,系统 将 在 左 侧 新 增 一 个 listitem 项 ,针对 此 项 ,在 右 侧 修改 
其 Text 和 Value 值 。 例 如 先 添 加 “东方 ”, 再 添加 “西方 ”, 最 后 单 击 【 确 定 ] 按 钮 ,使 之 返 
回 到 主 工作 区 界面 。 通 过 此 操作 ,使 此 下 拉 式 列表 框 有 了 两 个 选项 ,分 别 是 “东方 ”、 
“西方 ”。 

选中 下 拉 式 列 表 框 按钮 ,在 [属性 了】 面板 中 找到 这 个 按钮 的 ID, 把 其 ID 修改 为 “pf”, 把 
Text 属性 修改 为 皂 提交 卫 。 

选中 Label 控件 ,利用 [属性 ] 面 板 修改 其 ID 为 “jielun” ,Text 属性 值 为 空白 。 

4) 为 按钮 添加 C# 代 码 

以 鼠标 双击 按钮 [提交 】 ,此 时 系统 自动 创建 出 一 个 ceshi. aspx. cs 的 文件 ,并 把 此 文件 
显示 在 主 工作 区 中 ,如 图 2-15 所 示 。 
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| 区 pfClick(object sender EventAre » 

并 wing Systen Web. UT YebControls: = 

11 | using Systen Web. UT WebControls YebParts; 
12 ~ using Systen Yal Ling; 

13 


public partial class ceshi ; Systen Web WT. Paee 


protacted void Page_Loud(object sender, EventAres «) [3 
t 


} a 
3 void pf Click(sbjeet sender, Eventhres «) 


图 2-15 测试 试卷 程序 的 C# 代码 的 框架 


从 图 2-15 可 以 看 出 ,函数 pf_Click 就 是 对 应 于 按钮 “pf 的 Click 事件 要 执行 的 代码 。 
即 执行 答案 判定 并 给 出 结论 。 添 加 的 代码 如 图 2-16 所 示 。 


55 和 void pf_Click(object sender, Eventhres e) 
24 

25 int sss = 0; 

26 这 (T1, Text, Trin() ==" 北 京 ") 

27 sss=ssst30; 

28 证 (T2.Text,Trin() == "106") 

29 sss = sss + 30. 

50 证 (T3, Selectedyalue==" 东 方 ") 

31 sss=ssst40; 

32 Sco, Text = sss, ToString () ; 

33 证 (sss == 100 

34 jielun. Text = " 太 棒 了 ! Great!" 

35 else if (sss >= 70) jielun.Text = 1 很 好 1 不 错 嘛 !" ; 
36 else if (sss = 30)， a Text = "有 差距 ， 尚 需 努 力 !" ; 
37 else jielun Text = “您 与 要 求 相 差 较 多 ， 请 努力 呀 | "; 
38 

39ir } 


图 2-16 测试 试卷 程序 的 C# 代码 


5) 保存 程序 并 预览 程序 效果 

首先 ,使 用 快捷 键 Ctrl 十 S 保存 文件 。 

然后 , 按 快捷 键 Ctrl 十 F5 ,系统 将 启动 浏览 器 ,在 其 中 显示 动态 网 页 ceshi 的 内 容 , 对 网 
页 的 运行 效果 进行 测试 。 


@.2 C# 语 法 基础 


2.2.1 基于 C# 的 ASP.NET 程序 的 基本 结构 


在 VS2008 下 ,ASP.NET 程序 至 少 由 两 个 文件 构成 。 其 一 是 扩展 名 为 aspx 的 文件 ,其 
中 主要 保存 了 页 面 设计 ,格式 信息 ; 其 二 是 扩展 名 为 aspx. cs 的 文件 ,其 中 保存 了 C# 的 语 
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句 , 主 要 负责 对 网 页 中 动态 内 容 的 处 理 。 

1. aspx 文件 内 容 的 基本 结构 

打开 一 个 新 增 的 动态 网 页 文件 ,切换 到 “ 源 ” 代 码 方式 下 ,可 以 看 到 如 图 2-17 所 示 的 基 
本 结构 。 


客户 渍 对象 和 事件 ~ 可 伯 
二 hh Fage Laneusee="C#" AutchventWireup="true" CodeBehind= Deteult. aspx. cs" Irerits= NyTest. Defeult™ WD 
| IDOCTIP WE mac) HTHL 10 Transitional//EN" http: /ewe #3 org/TR/Ahtnl L/DTO/xhtall-transitionl. dta" 


w3. org/1999/xhtal" 


2-17 aspx 文件 的 基本 结构 


文件 的 第 1 行 说 明 此 动态 网 页 所 采用 的 计算 机 语言 是 C# ,本 网 页 所 对 应 的 C# 源 程 
序 为 Default. aspx. cs, 此 网 页 是 项 目 MyTest 中 的 一 个 子 页 面 。 第 4 一 6 行 是 网 页 的 头 文 
件 ,过 title 二 和 过 /title 二 之 间 的 内 容 是 网 页 的 标题 ,本 网 页 标题 为 “无 标题 页 ”。 第 7~13 
行 是 网 页 的 主体 部 分 ,其 中 包括 一 个 运行 于 服务 器 上 的 表单 (<form 二 ) 和 一 对 三 div 二 
标记 。 

开发 者 向 页 面 中 添加 的 内 容 都 将 被 放置 在 < div 之 和 二 /div 之 之 间 。 在 二 div 之 和 
</div> 之 间 , 开 发 者 可 以 嵌入 HTML 语言 的 各 种 控制 符号 。 

2, aspx, cs 文件 内 容 的 基本 结构 

在 动态 网 页 的 设计 视图 下 ,向 网 页 中 添加 一 个 按钮 Button ,其 默认 的 ID 为 “Button1”， 
修改 其 Text 属性 为 “测试 "。 然 后 ,以 鼠标 双击 此 按钮 ,系统 会 自动 切换 到 其 aspx. cs 的 编 
程 状 态 , 获 得 的 操作 界面 如 图 2-18 所 示 。 

从 图 2-18 可 知 ,第 1 一 12 行 是 一 组 自动 添加 的 using 语句 , 列 人 了 本 程序 要 引入 的 包 
(也 称 名 称 空间 )。 由 于 C# 是 典型 的 面向 对 象 程序 设计 ,VS2008 提供 了 众多 的 class( 类 ) 
供 开 发 者 使 用 。 因 VS2008 中 内 置 class 的 数量 很 大 ,为 便于 管理 ,VS2008 把 这 些 class 归 
类 存储 ,被 分 别 存放 在 不 同 的 名 称 空间 中 。 如 果 开 发 者 需要 引用 某 个 名 称 空间 ,就 需要 用 
using 语句 进行 声明 。 

第 14 行 是 个 namespace 语句 ,表示 定义 了 一 个 名 字 为 MyTest 的 名 称 空间 ,而 且 此 名 
称 空间 的 作用 范围 为 第 14 一 28 行 ,表示 本 网 页 的 全 部 C# 代 码 都 被 定义 在 这 个 名 称 空间 
中 ; 第 16 一 27 行 表示 本 网 页 定义 了 一 个 类 (class) ,类 的 名 称 为 _Default, 它 继承 于 VS2008 
系统 内 置 的 类 Page, 这 个 类 中 包括 了 两 个 函数 : 其 一 是 Page_Load, 可 以 把 网 页 启动 时 需要 
直接 运行 的 代码 编写 在 这 个 函数 中 ; 其 二 是 Buttonl_Click, 在 其 中 输入 按钮 Buttonl 被 单 
击 时 需要 执行 的 代码 。 

注意 : 响应 Button 对 象 的 Click 事件 的 方法 名 默认 为 “对 象 ID_Click”。 由 于 Button 
对 象 的 默认 ID 为 Button1。 因 此 ,如 果 在 更 改 Button 对 象 的 ID 前 创建 该 对 象 的 Click 方 
法 , 则 该 方法 名 通常 为 Button1_Click, 即 使 以 后 修改 了 该 对 象 的 ID ,其 对 应 的 Click 方法 名 
称 也 不 会 自动 改变 。 
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党 MyTest. Default 和 


1 器 using System; 

2 | using System, Collections; 

3 | using System. Configuration; 

4 | usine System. Data; 

5 | using System. Ling; 

6 | using System. Web; 

Ti| using System. Web. Security; 

8 | using System. Web. UT; 

9 | using System. Web. UI. HtmlControls; 
10 | using System. Web. UI. WebControls; 
11 | using System.Web. UI. WebControls. WebParts; 
12 -using System. Yml. Ling; 


14 口 namespace NyTest 
{ 


lB6m public partial class Default : System.Web. UI.Page 
17 { 

180 protected void Page_Load(object sender, Eventhrgs e) 
19 

20 | 

21 } 

23 尖 protected void Buttonl_Click(object sender, EventAres e) 
2 

4 

基 

26 

27 } 

28:5} 


图 2-18 aspx. cs 文件 的 基本 结构 


因此 可 以 说 ,这 个 aspx. cs 文件 由 引用 名 称 空 间 的 语句 (若干 using) 和 新 定义 的 名 称 空 
间 MyTest 构成 。 在 名 称 空间 MyTest 中 ,新 定义 了 一 个 面向 当前 网 页 的 class,class 的 名 
称 与 网 页 名 称 类 似 ,这 个 class 包含 了 两 个 函数 ,一 个 是 Page_Load 函数 , 另 一 个 是 响应 按 
钮 的 Click 事件 的 代码 所 构成 的 函数 。 

处 于 class 中 的 函数 也 称 方法 。 

3. 以 VS2008 设计 动态 网 页 的 基本 方法 

基于 上 述 分 析 , 笔 者 认为 ASP.NET 动态 网 页 的 设计 可 以 分 为 两 个 部 分 : 其 一 是 在 可 
视 化 的 界面 下 以 鼠标 拖 动 的 方式 组 织 页 面 上 的 控件 ,配置 网 页 界面 ; 其 二 是 利用 VS2008 
系统 提供 的 C# 集 成 化 环境 开发 程序 ,为 响应 各 个 按钮 的 Click 事件 而 编写 代码 。 

在 这 一 过 程 中 ,要 充分 借用 VS2008 提供 的 集成 化 开发 环境 ,充分 利用 系统 提供 的 各 
种 类 和 控件 。 因 此 逐步 地 学 习 并 掌握 C# 中 的 各 种 控件 和 类 的 属性 .方法 ,是 掌握 
ASP.NET 开发 动态 网 站 技术 的 必要 条 件 。 

4. ASP. NET 网 页 的 两 种 页 模型 形式 

1) 代码 隐藏 页 模型 

VS2008 自动 构成 的 ASP .NET 网 页 至 少 由 两 个 文件 组 成 ,真正 地 实现 了 界面 设计 与 
后 台 逻 辑 处 理 代码 的 分 离 , 适 合 于 多 个 人 员 共同 开发 网 站 的 情形 。 它 清晰 地 分 开 了 界面 设 
计 与 后 台 逻 辑 代码 设计 ,便于 美工 人 员 集中 精力 设计 界面 ,而 把 复杂 的 业务 处 理 交 由 擅长 程 
序 编码 的 人 员 承 担 。 这 种 结构 称 为 代码 隐藏 页 模型 。 

在 代码 隐藏 页 模型 中 ,显示 界面 的 代码 包含 于 . aspx 文档 中 ,而 逻辑 代码 (C# 程 序 ) 包 
含 于 相应 的 aspx. cs 文档 中 。 为 了 说 明 二 者 的 协作 关系 ,需要 在 aspx 文档 中 的 @page 指令 
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中 说 明 需 要 引用 的 外 部 aspx. cs 文件 。 从 图 2-17 可 以 看 出 , 首 行 的 语句 “二 %@ Page 
Language="C#" AutoEventWireup= "true" CodeBehind= "Default. aspx. cs" Inherits= 
"MyTest. Default”% 过 就 清楚 地 表明 了 开发 语言 为 C# ,要 引用 的 外 部 逻辑 代码 文件 为 
Default. aspx. cs, 而 且 这 个 网 页 隶属 于 MyTest 项 目 。 

在 这 种 模型 中 ,如 果 外 部 逻辑 文件 找 不 到 ,或 者 外 部 逻辑 文件 错误 ,将 会 导致 "未 能 加 载 
类 型 "MyTest. Default1"” 的 错误 。 

2) 单 文件 页 模型 

归根 到 底 ,ASP.NET 的 Web 应 用 程序 是 一 种 高 级 语言 源 程序 文件 。 因 此 对 于 这 种 文 
件 可 以 使 用 任何 一 种 纯 文本 编辑 器 设计 。 在 一 些小 型 的 应 用 中 ,也 有 程序 员 把 ASP .NET 
的 界面 设计 和 逻辑 代码 集成 在 一 个 文档 中 ,不 采用 独立 aspx. cs 文档 。 这 种 结构 模型 称 为 
单 文件 页 模型 ,如 图 2-19 所 示 。 


1: <%@ Page Language= C# %> 

2 《IDOCTYPE html PUBLIC "-//W3C//DID XHTIL 1.0 Transitional//EN" 
ii "http://www. wi, org/ TR/xhtml1l/DTD/xhtmll-transitional. dtd"> 

$a tn xnlns=" http: yy, YW3, org/ 1999/xhtnl"” 

6 CScript runat="server" 

人 protected ee btnSave_Click (object sender, Eventhrgs e) 
9 

10 } 

11 上 《VScript> 

129 head runat="server" 

13 天虹 Ytite> 

14 .F</head> 

15g <body> 

08 《form id="fornl" rnat="server"》 

17 《div> 

188 《asp:TextBox ID="txtXh”runat="serVer">《/aspiTextBox> 
19 《asp:Button ID="btnSave" runat="server” Text=" 输 入 " onclick="btnSave_Click" /> 

20| /div> 

2 /forn> 

22 上 《Abody> 

23 《Ahtmn1> 

24 


2-19 单 文件 页 模型 的 基本 结构 


在 单 文件 页 模型 的 结构 中 ,需要 在 “@Page” 语 句 中 声明 开发 语言 ,然后 把 逻辑 代码 用 
特定 的 标记 所 Script Runat="Server" 二 和 二 /Script 之 之 间 。 

采用 单 文件 页 模型 的 ASP.NET 应 用 程序 不 会 产生 找 不 到 外 部 文件 的 问题 ,但 界面 设 
计 与 逻辑 代码 集成 于 一 个 文档 下 ,会 产生 界面 设计 与 逻辑 代码 开发 的 协调 问题 ,不 利于 大 型 
项 目的 开展 。 相 比 而 言 , 采 用 代码 隐藏 页 模型 具有 更 好 的 远景 。 


2.2.2 C# 的 数据 类 型 


1. 常见 的 数据 类 型 

C# 支 持 种 类 繁多 的 数据 类 型 ,本 节 只 介绍 最 常用 的 几 种 。 

1) 数值 型 数据 

数值 型 数据 是 应 用 非常 广泛 的 一 类 数据 ,其 特点 是 能 够 参与 各 种 数学 运算 。 在 ASP.NET 
的 C# 中 ,常见 的 数值 型 数据 有 整 型 和 浮 点 型 两 类 。 

所 谓 整 型 ,就 是 数学 中 的 整数 ,如 1,2,3,… 和 一 100、 一 78 等 都 属于 整 型 。 根 据 其 表示 
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数值 的 范围 不 同 ,可 以 分 为 int 型 和 1long 型 两 类 。 其 中 int 型 为 32 比特 有 符号 整数 , 取 值 范 
围 在 正 负 21 亿 之 间 ,long 型 为 64 比特 有 符号 整数 , 取 值 范围 在 正 负 10E19 之 间 。 

所 谓 浮 点 数 ,就 是 数学 中 带 有 小 数 部 分 的 数值 ,如 1. 25,3. 87,2. 0 等 都 属 浮 点 数 。 根 据 
它 表示 数据 的 范围 不 同 , 可 以 分 为 单 精度 型 (float) 和 双 精 度 型 (double) 两 种 类 型 。 

例如 : 


int x,y; 
float w,z; 
表示 定义 两 个 整 型 的 未 知 数 x 和 y, 然 后 定义 两 个 单 精度 型 的 浮 点 数 w 和 z。 
2) 布尔 型 数据 
布尔 型 数据 也 称 为 逻辑 型 数据 ,其 值 只 有 两 个 状态 : true 和 false( 即 * 真 "和 “ 假 ”)。 
布尔 型 数据 用 bool 定义 ,主要 用 于 各 种 逻辑 运算 。 例 如 : 


bool hunfou = false; 


表示 定义 了 一 个 布尔 型 数据 hunfou ,而 且 其 初始 值 为 false。 
3) 字符 串 型 数据 
字符 串 型 数据 , 即 由 一 串 字符 构成 的 数据 ,有 时 也 简称 为 字符 型 数据 。 
字符 串 型 数据 用 string 定义 ,主要 用 于 表达 人 名 \ 语 句 、 地 名 等 各 种 字符 串 型 信息 。 例 如 ;: 


String xm= " 张 三 "; 


表示 定义 了 一 个 字符 串 数据 xm, 而 且 其 初始 值 为 " 张 三 "。 
4) 日 期 时 间 型 数据 
日 期 时 间 型 数据 , 即 由 一 串 具备 日 期 格式 的 字符 构成 ,能 够 参与 一 般 的 加 减 运算 。 
日 期 时 间 型 数据 用 DataTime 定义 ,主要 用 于 表达 具体 的 日 期 或 时 间 。 例 如 : 


DateTime dt = DateTime. Now; 


表示 定义 了 一 个 日 期 时 间 型 数据 dt, 而 且 其 初始 值 为 当前 日 期 和 当前 时 间 。 而 “DateTime 
dt 三 DateTime. Today;” 则 表示 获取 当前 日 期 。 

5) 数组 

数组 指 多 个 同 种 类 型 的 数据 构成 的 一 种 数据 类 型 ,比如 整 型 数组 指 多 个 整 型 数据 结合 
在 一 起 构成 的 复合 类 型 ,这 是 一 种 典型 的 引用 类 型 。 例 如 : 


int [Jaa= new int[10]; 


表示 定义 了 一 个 由 10 个 整数 构成 的 数组 ,如 果 需 要 提取 数组 中 的 某 个 数据 ,可 以 利用 数组 
下 标 来 指定 它 。 

需要 注意 的 是 ,在 C# 中 ,数组 的 下 标 从 0 开始。 要 提取 上 述 数 组 aa 中 的 第 4 个 数 ,可 
用 aa[3] 来 表示 。 

2. 对 C# 数 据 类 型 的 归 类 

C# 支 持 种 类 繁多 的 数据 类 型 ,但 其 大 致 可 以 被 分 为 两 大 类 。 

1) 值 类 型 

顾名思义 , 值 类 型 就 是 直接 存放 真正 的 数据 ,具备 明确 取 值 的 类 型 。 值 类 型 有 3 大 类 : 
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基本 型 .结构 型 和 枚 举 型 。 而 基本 型 中 又 包括 整 型 . 浮 点 型 和 布尔 型 等 。 

2) 引用 类 型 

在 计算 机 中 ,为 表示 相对 复杂 的 一 种 数据 (如 数组 对象 等 ) ,需要 依靠 标记 内 存 地 址 来 
表达 这 个 数据 ,这 种 具有 复杂 结构 的 数据 位 于 受 系 统统 一 管制 的 堆 上 。 这 种 类 型 叫做 引用 
类 型 。 

引用 类 型 中 包括 数组 .接口 ,class、 委 托 等 。 常 见 的 字符 串 类 型 就 是 一 种 引用 类 型 , 它 
属于 class 类 型 的 范畴 。 

在 C# 应 用 程序 中 ,在 以 引用 类 型 作为 参数 的 函数 或 方法 中 ,通过 地 址 实现 参数 传递 。 

3. 基本 型 与 基于 类 的 类 型 

对 于 C# 的 值 类 型 数据 来 讲 ,其 数据 类 型 中 仅 包含 了 其 数据 而 不 包括 对 这 种 数据 进行 
操作 的 各 种 方法 ,这 种 类 型 就 是 基本 型 。 

随 着 面向 对 象 程序 设计 的 普及 ,对 基 类 型 的 数据 提出 进行 各 种 操作 的 要 求 。 例 如 对 字 
符 串 去 除 两 端 空 格 \ 求 长 度 ,对 整 型 数据 的 类 型 转换 等 。 为 此 ,C# 对 基本 类 型 的 数据 进行 
了 扩展 ,把 它们 变 成 了 既 保存 数据 ,又 封装 操作 方法 的 特定 对 象 。 于 是 基于 类 的 数据 类 型 出 
现 了 。 

基于 类 的 数据 类 型 是 一 种 引用 类 型 ,基本 类 型 和 基于 类 的 类 型 可 以 隐 式 地 相互 转化 。 
在 C# 的 数据 类 型 中 ,string 是 一 种 基本 类 型 ,与 C 语言 的 string 类 型 一 致 ,而 String 是 面 
向 字符 串 的 类 ,是 一 种 基于 类 的 字符 串 类 型 。int 是 一 种 基本 类 型 ,而 Int32 则 是 一 种 基于 
类 的 整 型 。 

4. 常量 .变量 与 标识 符 命名 

1) 常量 

常量 就 是 生活 中 的 常数 .不 能 发 生变 化 的 量 , 常 量 的 特点 是 名 称 和 数据 内 容 二 者 合 一 ， 
没有 区 分 。 例 如 ,数值 “9? 就 是 一 个 数值 型 常量 ,其 名 字 和 内 容 都 是 "9”; 人 名 “李白 ”也 是 一 
个 常量 , 它 是 字符 型 常量 。 常 见 的 常量 主要 有 两 种 。 

(1) 字符 串 常 量 。 以 英文 的 引号 作为 标志 ,一 般 使 用 双 引 号 。 例 如 "zhangsan"、 
"Wangyi" 等 。 

(2) 数值 型 常量 。 不 需要 特定 标记 ,但 其 中 的 每 个 符号 只 能 为 数码 。 例 如 ,800、700、 
400、657. 28 等 。 

在 具体 的 程序 开发 中 ,为 了 明确 地 表示 某 个 常量 的 含义 ,或 者 便于 直接 对 程序 中 使 用 此 
常量 的 地 方 进行 统一 处 理 , 也 可 以 对 常量 进行 定义 。 定 义 常量 需要 以 const 关键 字 标 注 ， 
例如 ， 


const string xx= " 张 三 "; 


表示 定义 了 一 个 常量 xx, 其 值 恒定 为 “ 张 三 ”, 不 可 在 程序 中 修改 。 

2) 变量 

顾名思义 ,变量 是 其 值 可 以 发 生变 化 的 量 , 有 点 类 似 于 中 学 数学 中 的 未 知 数 x。 在 计算 
机 程序 设计 中 ,每 个 变量 都 有 一 个 变量 名 称 , 其 中 可 以 存储 各 种 各 样 的 内 容 。 因 此 ,变量 可 
由 变量 名 称 和 变量 内 容 两 部 分 组 成 。 

在 C# 中 ,变量 在 使 用 前 必须 先 声明 ,变量 的 类 型 一 旦 确定 ,就 只 能 存储 对 应 类 型 的 内 
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容 。 例 如 ,字符 型 变量 只 能 存储 字符 型 内 容 , 整 型 变量 只 能 储存 整 型 数值 。 

3) 变量 命名 规范 

变量 的 名 称 在 计算 机 中 以 标识 符 的 形式 存在 。 作 为 变量 名 称 的 字符 串 必 须 满足 以 下 
条 件 。 

(1) 变量 名 必须 以 字母 或 者 $ .下 划 线 开 头 ,中 间 不 能 带 有 空格 和 标点 符号 。 

(2) 变量 名 以 字符 串 的 形式 出 现 , 但 不 带 有 引号 。 也 就 是 说 ,在 计算 机 系统 中 ,计算 机 
一 旦 发 现 带 有 引号 的 字符 串 ,就 认定 这 是 一 个 字符 型 常量 ; 只 有 不 带 引 号 的 字符 串 , 才 被 认 
定 为 变量 名 称 。 

(3) 根据 变量 的 预定 义 类 型 ,可 以 向 变量 中 存储 内 容 。 

(4) 在 一 个 作用 域 范围 内 ,一 个 变量 只 能 被 定义 一 次 ,只 能 被 定义 为 一 种 类 型 。 

(5) C# 语言 的 保留 字 不 能 作为 变量 名 称 使 用 。 


例如 ， 
String al; // 声 明 一 个 字符 串 类 型 的 变量 al; 
int i=10; // 定 义 一 个 整 型 变量 i, 而 且 为 此 变量 赋值 10。 


例如 ,xx、xl、hello、Good 等 都 是 合法 的 变量 名 称 ,而 5x、x/5、x x* 8、98RT 等 都 不 是 合 
法 的 变量 名 称 。 另 外 ,由 于 C# 语 言 区 分 大 小 写字 母 ,XX 与 xx、Hello 与 HELLO X8 与 
x8 ,strBoy 与 strboy 都 是 不 同 的 变量 名 称 。 


2.2.3 C# 的 运算 符 


C# 支 持 种 类 繁多 的 运算 符 ,本 节 只 介绍 最 常用 的 几 种 。 

1. 主要 的 算术 运算 符 

C# 的 主要 算术 运算 符 有 加 (十 ) , 减 (一 ) 、 乘 (x )、 除 (/)、 求 余数 (%%) 五 种 。 

这 些 运算 符 全 部 是 二 元 运算 符 , 即 在 运算 符 两 侧 各 有 一 个 数值 型 数据 ,利用 运算 符 进 行 
运算 。 在 运算 过 程 中 ,简单 数据 类 型 可 以 自动 地 转化 为 相对 复杂 的 数据 类 型 。 

例如 ， 


float y=8-5/4+21.5 


结果 为 : y=28. 5, 因 为 5/4 是 两 个 整 型 相 除 ,结果 等 于 1 。 

2. 比较 运算 符 

两 个 数据 进行 比较 ,需要 使 用 比较 运算 符 , 比 较 运算 后 的 结果 为 布尔 型 量 。 常 用 的 比较 
运算 符 有 如 下 几 个 : 相等 比较 (==)、 大 于 (二 ) ,小 于 (< 过) .大 于 或 等 于 、( 记 =)、 小 于 或 等 
于 (过 =) ,不 等 于 (!=)、 类 型 检测 (is) 。 

3. 逻辑 运算 符 

两 个 布尔 型 数据 进行 与 .或 运算 ,需要 使 用 逻辑 运算 符 。 常 用 逻辑 运算 符 形式 如 下 : 

。 与 关系 (&&) 

。 或 关系 (| ) 

在 实际 操作 中 ,逻辑 运算 符 的 两 侧 经 常 是 两 个 比较 运算 式 。 例 如 : 


x>=5| y<4 
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4. 位 运算 符 

位 运算 符 , 指 按照 二 进 制 位 进行 操作 的 运算 符 。 比 如 按照 二 进 制 位 进行 左右 移 位 ,或 者 
两 个 数值 按照 二 进 制 形式 进行 与 或, 非 运 算 。 

1) 移 位 运算 

左 移 位 (二 <) : 向 左 移 动 若干 位 。 例 如 4<<3 ,代表 把 数据 4 向 左 移动 3 位 ,结果 为 
32。 对 于 一 个 较 小 的 正 整 数 ,每 左 移 1 位 ,相当 于 数值 乘 以 2 。 

右 移 位 (之 > ): 向 右 移动 若干 位 。 例 如 4 过 >>2, 代 表 把 数据 4 向 右 移动 2 位 ,结果 为 1。 
对 于 一 个 较 大 的 正 整数 ,每 右 移 1 位 ,相当 于 数值 除 以 2。 

2) 位 的 “与 或 非 ? 运 算 

对 于 任意 两 个 数值 ,可 以 按照 二 进 制 位 进行 与 或, 非 运 算 。 对 应 的 操作 符号 是 ， 

。 与 (&) 

。 或 (|) 

“ 非 (~) 

。 蜡 或 () 

5. 自 增 自 减 运算 符 

为 提高 编程 效率 ,C# 支持 变量 的 自 增 和 自 减 运算 。 

1) 自 增 运 算 

自 增 运算 , 指 变量 自动 增加 其 值 的 运算 。 常 见 的 符号 有 两 种 形式 :“x 十 十 ;” 或 “十 十 x;” 
前 者 表示 先进 行 其 他 运算 ,然后 再 执行 自 增 操 作 。 后 者 表示 先进 行 自 增 运 算 , 再 进行 其 他 

2) 自 减 运算 

自 减 运算 , 指 变 量 自动 减少 其 值 的 运算 。 常 见 的 符号 有 两 种 形式 :“x 一 一 ;” 或 “一 一 x;” 
前 者 表示 先进 行 其 他 运算 ,然后 再 执行 自 减 操作 。 后 者 表示 先进 行 自 减 运 算 , 再 进行 其 他 
运算 。 

3) 扩展 操作 

对 于 在 当前 数据 基础 上 进行 处 理 , 然 后 把 操作 结果 存 回 当前 数据 的 操作 ,可 以 看 做 自 
增 、 自 减 运 算 的 扩展 操作 。 其 常用 符号 有 : 十 ==( 自 加 赋值 ) ,一 二 ( 自 减 赋值 )、x=( 自 乘 赋 
值 ) 和 /=( 自 除 赋值 ) 。 

4) 示例 

已 知 “int x= 一 5,y 王 6,z 一 7;”, 下 列 每 个 语句 独立 地 执行 , 则 


int a=x+ (y++); // 结 果 : a= 11, y=7; 
int b=x+ (++y); // 结 果 : b= 12, y=7; 
int c=x+ (-- 2z); // 结 果 : c=11,z=6; 
zx=6; // 结 果 : z= 42; 
XxX-=Yy; // 结 果 : Em 


2.2.4 C# 的 基本 语句 


和 其 他 高 级 语言 一 样 ,C# 也 提供 了 几 种 常见 的 控制 语句 ,用 于 控制 程序 的 走向 。 常 见 
的 控制 语句 包括 : 分 支 语 句 (也 称 选择 语句 ) 和 循环 语句 。 另 外 ,赋值 语句 和 捕捉 异常 语句 
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也 是 C# 设 计 中 常用 的 语句 格式 。 

C# 规 定 : C# 的 语句 区 分 大 小 写字 母 ,每 个 语句 必须 以 分 号 "; ?结束 ,一 行 中 允许 输入 
多 个 语句 。 

1. 赋值 语句 


赋值 语句 是 各 种 高 级 语言 中 应 用 最 普遍 的 语句 ,表示 把 一 个 常量 或 者 变量 赋值 给 另外 
一 个 变量 的 操作 。 赋 值 使 用 符号 “二”。 例 如 : 


int x=5; // 把 常量 5 赋值 给 整 型 变量 x; 

String ss = " 李 薄 "; // 把 字符 串 常量 " 李 萍 "赋值 给 字符 串 变 量 ss; 
int i,jyk,l; i=j=k=1=6; // 同 时 把 6 赋值 给 整 型 变量 i, j,k,1。 

2. 分 支 语句 


1) 二 路 分 支 语句 

二 路 分 支 语句 为 程序 的 走向 提供 两 种 可 能 ,对 于 满足 条 件 的 情况 ,执行 第 一 个 模块 的 代 
码 ,否则 执行 第 二 个 模块 的 代码 。 提 供 二 路 分 支 的 语句 是 if 分 支 语句 。if 语句 的 基本 格 
式 为 ， 

if( 条 件 式 ) {满足 条 件 的 模块 ; } else { 不 满足 条 件 执行 的 模块 ; } 


如 果 程 序 在 不 满足 条 件 时 不 执行 任何 代码 , 则 可 以 省 略 else 子 句 ,把 这 个 语句 简化 为 
以 下 格式 : 


(条件 式 ){ 满 足 条 件 的 模块 ; } 


2) 多 路 分 支 语句 
当 需 要 判断 的 条 件 比 较 多 时 ,可 以 使 用 switch 语句 进行 多 路 分 支 的 判断 。switch 语句 
中 可 以 包含 多 个 case 区 段 ,每 一 个 case 后 可 以 指定 一 个 常数 。 其 基本 格式 为 : 
switch( 变 量 或 表达 式 ) { 
case 常量 式 1: 语 句 序 列 1; 


case 常量 式 2: 语 句 序 列 2; 
case 常量 式 3: 语 句 序 列 3; 


default: 语 句 序列 n; } 


注意 : 如 果 满 足 条 件 的 常量 对 应 的 语句 序列 中 不 包含 “break;” 语 句 , 则 可 能 从 满足 条 
件 的 语句 序列 开始 执行 ,把 其 他 常量 式 对 应 的 语句 序列 也 一 并 执行 了 。 所 以 ,应 该 在 每 个 语 
句 序 列 中 恰当 地 添加 “break; ”语句 。 

3. 循环 语句 

C# 支 持 的 循环 语句 有 for 语句 、while 语句 、do-while 语句 和 foreach 语句 。 其 中 for 
语句 常常 用 于 明确 循环 次 数 的 循环 操作 ,while 语句 和 do-while 语句 则 针对 循环 条 件 明确 、 
但 循环 次 数 不 易 知道 的 循环 操作 ,foreach 则 主要 面向 集合 操作 。 

1) for 语句 

for 语句 的 基本 格式 为 : 


for( 初 始 值 ; 循环 条 件 ; 循环 控制 ){ 需 要 循环 执行 的 代码 ; } 
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例如 : 


int sum= 0; 
for(int i=1;i<=100;i++) sum= sum+ i; 
// 把 1~100 的 数据 累加 到 sun 中 ,明确 地 知道 循环 次 数 ; 
2) while 语句 
while 语句 的 基本 格式 为 ， 


while( 循 环 条 件 ) { 循 环 体 语句 ; } 


在 这 种 循环 结构 中 ,一 般 需 要 预先 设 定 循环 控制 变量 的 初 值 ,而 且 要 在 循环 体 中 对 循环 
控制 变量 进行 修正 。 如 果 循 环 条 件 恒 为 true, 为 避免 出 现 死 循环 ,就 需要 在 循环 体 中 包含 
“break; ”语句 。 例 如: 

int sum= 0; int i=1; 

while(i<=100) {sum= sum+ i; i++; } 

// 把 1~100 的 数据 累加 到 sum 中 ,以 i 的 值 小 于 或 等 于 100 作为 循环 条 件 ; 

3) do-while 语句 

do-while 语句 的 基本 格式 为 ， 

do {循环 体 语句 ; } while( 循 环 条 件 ) 

在 这 种 循环 结构 中 ,一 般 也 需要 预先 设 定 循环 控制 变量 的 初 值 ,而 且 要 在 循环 体 中 对 循 
环 控制 变量 进行 修正 。 如 果 循 环 条 件 恒 为 true, 为 避免 出 现 死 循 环 ,就 需要 在 循环 体 中 包含 
“break; "语句 。 

与 while 语句 相 比 , 此 语句 先 执行 一 次 循环 体 , 再 进行 循环 条 件 判 定 。 因 此 在 这 种 循环 
结构 中 ,循环 体 至 少 有 一 次 执行 的 机 会 ,而 在 while 结构 中 则 存在 循环 体 不 能 获得 执行 机 会 
的 可 能 性 。 例 如 ， 

int sum= 0; int i=1; 

do {sum= sum+ i; i++; } while(i<= 100); 

// 把 1 一 100 的 数据 累加 到 sun 中 ,以 i 的 值 小 于 或 等 于 100 作为 循环 条 件 ; 

4) foreach 语句 

foreach 语句 的 基本 格式 为 ; 


foreach( 类 型 变量 名 in 集合 名 称 ) {循环 体 语句 ; } 


foreach 语句 主要 用 于 控制 集合 操作 ,其 目标 是 把 集合 中 的 每 一 个 元 素 都 逐一 地 进行 处 理 。 

5) 两 个 跳 转 语句 

break 和 continue 是 两 个 跳 转 语句 。break 负责 跳出 最 近 封闭 的 一 层 循环 ,而 continue 
则 跳 转 到 包含 它 的 最 内 层 循环 的 开始 处 。 

4. 异常 处 理 语句 

异常 是 指 在 程序 执行 过 程 中 出 现 的 错误 。 尽 管 程序 开发 者 尽 可 能 保证 程序 代码 的 正确 
性 和 有 效 性 ,但 有 些 异 常 现象 是 难以 控制 的 。 比 如 网 站 访问 数据 库 , 就 可 能 由 于 数据 库 的 异 
常 或 者 网 络 阻塞 导致 读 取 数 据 失败 。 对 于 诸如 此 类 的 非 可 重复 性 问题 ,不 是 程序 开发 者 预 
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先 能 够 完全 控制 的 。 为 此 需要 在 程序 开发 时 预 留 一 些 措施 ,针对 异常 现象 进行 处 理 。 
异常 处 理 语句 包括 两 个 类 型 : 其 一 是 抛 出 异常 其 二 是 捕捉 异常 并 进行 处 理 。 
1) 抛 出 异常 
C# 使 用 “throw [表达 式 ]; ?来 抛 出 异常 。 
在 使 用 throw 语句 抛 出 异常 时 ,如 果 带 有 表达 式 作 为 参数 , 则 参数 必须 是 System. 
Exception 的 类 型 或 其 子 类 型 。 例 如 : 


throw new Exception(" 求 平方 根 的 数据 不 能 是 负数 !") ; 


如 果 throw 语句 不 带 表达 式 参数 , 则 此 语句 只 能 用 在 catch 模块 中 。 在 这 种 情况 下 , 它 
抛 出 的 异常 由 catch 模块 中 的 语句 直接 处 理 。 

2) 捕捉 异常 并 处 理 

C# 使 用 “try-catch” 语 句 捕 提 异 常 现象 并 进行 处 理 。 

捕捉 异常 并 处 理 的 语句 格式 是 : 

try { 可 能 产生 异常 的 语句 序列 ; } catch( 异 常 的 类 型 ) { 处 理 异常 的 语句 序列 ; } 

有 时 ,开发 者 希望 无 论 程 序 是 否 产生 异常 ,都 必须 运行 某 些 特定 的 语句 。 比 如 在 进行 数 
据 库 操 作 时 ,无 论 系统 是 否 产生 异常 ,在 数据 访问 结束 后 都 应 该 执行 关闭 数据 库 的 操作 。 此 
时 可 以 使 用 下 列 捕捉 异常 并 进行 处 理 的 格式 : 


try { 可 能 产生 异常 的 语句 序列 ; } 
catch( 异 常 的 类 型 ) { 处 理 异常 的 语句 序列 ; } finally {必须 要 执行 的 语句 序列 ; } 


2.2.5 简单 应 用 程序 实例 


在 VS2008 下 新 建 项 目 , 命 名 为 MyTest2, 然 后 分 别 创建 4 个 动态 网 页 文件 ,完成 以 下 
任务 。 

1. 数据 的 累加 

要 求 设计 一 个 数据 累加 器 , 当 在 文本 框 中 输入 一 个 整 型 数值 并 单 击 【 计 算 ] 按 钮 后 ,系统 
自动 计算 出 1 至 该 数值 之 间 的 累加 值 。 如 果 输 入 的 数据 小 于 1, 则 给 予 提示 “输入 的 数值 不 
能 小 于 1”。 界 面 如 图 2-20 所 示 。 

1) 设计 过 程 

首先 , 右 击 解决 方案 资源 管理 器 中 的 项 目 名 


称 ,在 弹出 的 快捷 菜单 中 选择 [添加 ]>[ 新 建 项 ]， |@ 回 * Emereen ex 
然后 选择 “Web 窗 体 ”, 并 命名 为 lsijiaqi。 为 项 目 | 京 eax | 部 避 samsv 本 PPepev 
新 增 一 个 Web 窗 体 。 | 

接着 ,直接 在 leijiadi aspx 的 设计 视图 下 输入 有 
文字 “累加 器 ”, 并 适当 调整 字体 .字号 。 

第 三 ,从 工具 箱 中 拖 动 一 个 文本 框 (TextBox ) 、 
文字 标签 (Label) 和 一 个 按钮 (Button) 控 件 到 窗 有, 

人 @ Intemet | 保护 楼 式 .启用 给 拆 100% vv 


体 中 。 
第 四 ,修改 文本 框 的 ID 为 txtData, 标 签 的 ID 2-20 ”累加 器 的 设计 模型 
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为 jieguo Text 属性 值 为 空 串 ,按钮 的 ID 为 cal、Text 属性 值 为 “计算 ”。 

最 后 ,保存 此 文档 。 

2) 关键 代码 

在 leijiaqi. aspx 的 设计 视图 下 双击 按钮 “cal”, 此 时 系统 自动 切换 到 leijiaqi. aspx. cs 的 
编程 状态 ,为 cal_Click 函数 添加 代码 ,得 到 的 代码 如 图 2-21 所 示 。 


protected void cal Click(object sender, Eventhres e) 


int xx = Convert.ToInt32(txtData. Text) ; 
if (xx < 1) 

Response. Write ("<script>alert ("输入 的 数值 不 能 小 于 1。' ) ;</script>》"); 
else 


int sun = 0; 
for (int i = 1; i 《= xx: iH) sun = sun + i; 
jieguo. Text = sum. ToString () ; 


图 2-21 累加 器 C# 代码 


3) 补充 说 明 

Response. Write 语句 输出 的 是 一 个 运行 于 客户 端的 JavaScript 语句 ,其 目的 是 为 了 产 
生效 果 较 好 的 警示 框 的 效果 。 

如 果 开 发 者 系统 提示 信息 以 弹出 警示 窗口 的 方式 出 现 , 则 可 以 使 用 *alert( ' 提 示 信 息 ')” 
命令 输出 提示 信息 ,但 注意 这 条 命令 必须 用 二 script 和 过/script 二 包括 起 来 。 

2. 计算 阶乘 的 值 

设计 阶乘 计算 器 , 当 在 文本 框 中 输入 一 个 整 型 数值 并 单 击 【 计 算 ] 按 钮 后 ,系统 自动 计算 
出 该 数值 的 阶乘 。 如 果 输 入 的 数据 小 于 1, 则 给 予 提示 :“ 输 入 的 数值 不 能 小 于 1”"。 如 果 输 
入 的 数据 大 于 15, 则 给 予 提示 :“ 输 入 的 数值 不 能 大 于 15”。 界 面 如 图 2-22 所 示 。 

1) 设计 过 程 


首先 ,新 增 Web 窗 体 : jiecheng。 | 计算 阶乘 

其 次 ,为 Web 窗 体 添加 如 图 2-22 所 示 的 控件 和 文字 ，| 输 各 钙 
并 分 别 修改 这 些 控件 的 ID 属性 和 Text 属性 。 计算 结果 是 ， [iiml 

最 后 ,保存 这 个 Web 窗 体 。 EE 

2) 关键 代码 


在 jiecheng. aspx 的 设计 视图 下 的 双击 按钮 “cal”, 此 时 图 2-22 计算 阶乘 程序 的 界面 图 
系统 自动 切换 到 jiecheng. aspx. cs 的 编程 状态 ,为 cal_Click 
函数 添加 代码 ,得 到 的 代码 如 图 2-23 所 示 。 

3. 对 星期 的 中 文 输出 

设计 一 个 自动 以 中 文 输出 星期 几 的 小 程序 。 当 单 击 按钮 [今天 星期 几 ?] 后 ,自动 在 后 面 
以 中 文 方式 输出 :“ 今 天 是 星期 * 1”( 要 求 * 处 是 正确 的 星期 之 值 ) 。 

1) 设计 过 程 

首先 ,新 增 Web 窗 体 : week_for。 

其 次 ,为 Web 窗 体 添加 如 图 2-24 所 示 的 按钮 和 文本 框 ,并 修改 按钮 的 ID 为 lookfor、 
Text 属性 值 为 “今天 星期 几 ?”, 然 后 修改 文本 框 的 ID 为 “txtData”。 
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23H protected void cal Click(object sender，Evertargs e) 

24 

25 int xx = Convert. ToInt32 (txtData. Text); 

26 if (xx < 

27 Response. Write ("<script>alert ("输入 的 数值 不 能 小 于 1。') ;</script>》"); 
28 else if (xx > 15) 

29 Response. Write("《script>alert ("输入 的 数值 不 能 大 于 15。') ;</script>") ; 
30 else 

31 

32 int jie = 1; 

33 for (int i = 1; i <= xx; iH) jie 民 i; 

34 jieguo. Text = jie.ToString() 

35 } 

36ir } 


图 2-23 计算 阶乘 程序 的 C# 代码 


今天 星期 几 ? | 


2-24 ”转换 星期 几 的 程序 界面 图 


最 后 ,保存 这 个 Web 窗 体 。 

2) 关键 代码 

在 weekfor. aspx 的 设计 视图 下 的 双击 按钮 “lookfor”, 此 时 系统 自动 切换 到 weekfor. 
aspx. cs 的 编程 状态 ,为 lookfor_Click 函数 添加 代码 ,得 到 的 代码 如 图 2-25 所 示 。 


230 protected void lookfor_Click(object sender, Eventhrgs e) 
24 和 

25: DateTine dt = ,DateTime。 Today: 

26: String str = ""; 

27 switch (dt. Re ToSt ring ()) 

28 { 

29: case "NMonday": str = "星期 一 "; break; 

30 case "Tuesday": str = "星期 二 " : break: 

31 case "Wednesday": str = "星期 三 "; break; 

32 case "Thursday : str =“" 星 期 四 "; break: 

33 case "Friday": str = "星期 五 " ; break; 

34 case "Saturday": str = "星期 六 "; break 

35i case "Sunday": str = "星期 日 休息 日 ! "; break: 
36: 

37 } txtData. Text = "今天 是 : " + str; 

38t } 


图 2-25 转换 星期 几 的 C# 代 码 


4. 判断 偶数 并 求 和 

要 求 设计 一 个 偶数 求 和 计算 器 , 当 在 文本 框 中 输入 一 个 整 型 数值 并 单 击 按钮 [计算 后， 
系统 自动 计算 出 1 到 该 数值 之 间 的 所 有 偶数 之 和 。 如 果 输 入 的 数据 小 于 1, 则 给 予 提示 “ 输 
和 人 的 数值 不 能 小 于 1”。 

1) 设计 过 程 

首先 ,新 增 Web 窗 体 : oushu。 

接着 ,为 Web 窗 体 添加 如 图 2-26 所 示 的 控件 和 文 
字 , 并 分 别 修改 这 些 控件 的 ID 属性 和 Text 属性 。 


最 后 ,保存 这 个 Web 窗 体 。 2-26 计算 偶数 之 和 的 程序 界面 图 
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2) 关键 代码 
在 oushu. aspx 的 设计 视图 下 的 双击 按钮 “cal”, 此 时 系统 自动 切换 到 oushu. aspx. cs 的 
编程 状态 ,为 cal_Click 函数 添加 代码 ,得 到 的 代码 如 图 2-27 所 示 。 


protected void cal_Click(object sender, Eventhrgs e) 
25 int xx = Convert. ToInt32(T1. Text): 
26 if (xx < 1) ， 
27 Response. Write("<script>alert ( 输入 的 数值 不 能 小 于 1。  ) ; </script>》"); 
28: 1 
图 else 
30 int sun = 0; 
31 for (int i = 1; i <= xx: i+t) 
32 if (i%2== 0 sum= sun+ti; 
33 txtData. Text = sum. ToString() ; 
3 } 


2-27 计算 偶数 之 和 的 C# 代 码 


&3 面向 对 象 程序 设计 


2.3.1 面向 对 象 程序 设计 的 基本 概念 


面向 对 象 的 程序 设计 思想 是 20 世纪 90 年 代 中 期 兴起 的 一 种 编程 思想 , 随 着 Windows 
的 兴盛 而 日 益 普及 。 面 向 对 象 程序 设计 的 基本 思想 就 是 设计 和 创建 class( 类 ) ,并 由 class 
生成 对 象 ,然后 由 对 象 完成 用 户 期 望 的 功能 。 

面向 对 象 的 程序 设计 已 经 成 为 当前 程序 设计 的 主流 思想 。 当 前 ,几乎 所 有 的 系统 开发 
都 是 基于 面向 对 象 的 程序 设计 思想 的 。 

1. 什么 是 面向 对 象 的 程序 设计 

什么 是 面向 对 象 的 程序 设计 ? 在 仔细 地 阐述 这 一 概念 之 前 , 先 阐述 客观 世界 中 的 一 个 
社会 现象 。 如 果 笔 者 想 开 一 个 餐馆 ,该 怎么 办 呢 ? 其 实 答案 很 简单 : 至 少 需 要 招聘 一 名 厨 
师 ,招聘 几 名 服务 员 ,还 要 招聘 财会 人 员 和 采购 人 员 。 在 这 个 过 程 中 ,厨师 .服务 员 , 财 会 人 
员 和 采购 人 员 的 名 字 并 不 重要 ,重要 的 是 各 类 人 员 必 须 具备 相应 的 技能 。 即 厨师 应 该 具备 
炒菜 的 技能 ,财会 人 员 具 备 会 计 和 收 款 能 力 ,采购 人 员 掌 握 行 情 并 能 够 买 到 合适 的 菜品 ,总 
之 ,笔者 需要 从 各 类 人 员 中 选择 具备 相应 技能 的 个 体 ,使 之 加 入 到 笔者 的 餐馆 中 来 。 当 各 种 
个 体 已 经 具备 ,餐馆 就 可 以 开张 了 。 如 果 笔者 需要 的 某 种 人 员 并 不 存在 ,那么 就 需要 寻找 一 
个 最 接近 需求 的 人 员 ,然后 对 这 个 人 进行 培训 ,逐步 使 之 达到 要 求 。 

对 这 一 过 程 进行 思考 ,我 们 会 发 现 : 笔者 在 招聘 人 员 时 是 按照 人 员 类 别 来 招聘 的 ,但 某 
个 个 体 应 聘 后 就 成 为 一 个 具体 的 实例 在 餐馆 中 存在 。 也 就 是 说 : 在 招聘 组 织 人 员 的 时 候 ， 
笔者 关注 的 是 某 个 类 别 的 人 员 是 否 存在 ,但 最 终 能 发 挥 作用 的 却 是 一 个 具体 的 个 体 。 比 如 ， 
笔者 招聘 厨师 ,笔者 的 关注 点 是 厨师 ,并 不 强调 一 定 是 某 个 具体 的 人 。 如 果 " 张 三 应聘 成 
功 ,那么 " 张 三 ? 就 会 以 一 个 具体 对 象 的 形式 存在 于 餐馆 之 中 ,并 且 发 挥 着 厨师 的 作用 。 在 这 
里 ,厨师 的 名 字 并 不 重要 ,但 只 要 是 厨师 ,就 必须 具备 厨师 的 技能 。 

进一步 思考 这 一 过 程 中 ,要 想 餐 馆 成 功 开张 ,对 餐馆 主人 的 要 求 是 什么 ? 答案 是 明确 
的 : 餐馆 主人 必须 要 掌握 餐馆 的 人 员 组 成 结构 ,了 解 每 一 类 人 员 的 专长 和 特点 ,明确 如 何 才 
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能 使 各 类 人 员 协 调 地 工作 。 

事实 上 ,面向 对 象 的 程序 设计 就 和 笔者 开 餐 馆 的 思路 是 一 样 的 。 在 程序 开发 过 程 中 , 开 
发 者 的 首要 任务 就 是 明确 新 程序 需要 由 哪些 种 类 的 对 象 构 成 。 接 着 ,利用 相应 的 类 (class) 
创建 对 象 ,并 修改 对 象 的 属性 取 值 ,为 对 象 撰写 响应 事件 的 程序 代码 就 可 以 了 。 因 此 ,在 面 
向 对 象 的 程序 设计 过 程 中 ,开发 者 需要 明确 系统 提供 的 类 (class) 有 哪些 ,每 个 类 产生 的 对 
象 有 哪些 属性 .哪些 方法 ,如何 才能 使 相关 的 几 种 对 象 协同 工作 。 可 以 说 ,学 习 面 向 对 象 的 
程序 设计 ,就 是 学 习 这 种 开发 工具 有 哪些 类 别 的 对 象 可 以 使 用 ,并 进而 使 这 些 对 象 在 同一 程 
序 内 部 协作 的 过 程 。 

2. 对 象 的 概念 

在 程序 设计 过 程 中 ,人 们 把 这 些 包含 动态 属性 和 静态 属性 的 客观 事物 通称 为 对 象 ,在 设 
计 程 序 过 程 中 综合 考虑 这 些 事物 的 静态 属性 和 动态 属性 ,把 描述 事物 静态 属性 的 状态 和 描 
述 事物 动态 属性 的 方法 封装 在 一 个 称 为 对 象 的 程序 块 中 。 

对 象 (object) 是 一 个 封闭 体 , 它 由 一 组 数据 和 施加 于 这 些 数据 上 的 一 组 操作 组 成 。 具 
体 地 说 ,客观 事物 中 的 一 个 活体 除了 具有 静态 的 属性 ,还 有 章 到 某 种 事件 后 做 出 反应 这 一 动 
态 属 性 。 由 于 对 象 是 对 客观 事物 的 抽象 化 ,那么 对 象 中 描述 客观 事物 的 静态 属性 的 数据 ,被 
简称 为 对 象 的 状态 ,对象 中 的 一 些 程序 代码 描述 客观 事物 遭受 刺激 后 所 做 出 的 反应 ,这 种 反 
应 是 客观 事物 的 动态 属性 ,被 称 为 对 象 的 方法 。 客 观 事物 遭受 到 的 刺激 被 称 为 事件 
(event)。 从 上 面 语义 可 以 知道 ,对 象 的 方法 (method) 往 往 与 一 定 的 事件 相对 应 。 

在 前 面 的 几 个 实例 中 ,放置 于 Web 窗 体 中 的 按钮 .文本 框 等 都 是 对 象 ,它们 都 既 具 有 
长 , 宽 和 颜色 等 静态 属性 ,同时 也 可 以 具有 面临 鼠标 单 击 事件 、 鼠 标 双 击 事件 时 的 代码 段 。 
程序 开发 的 过 程 就 是 在 窗 体 中 创建 不 同 的 对 象 ,并 设置 对 象 的 静态 属性 和 动态 方法 的 过 程 。 
这 种 方法 被 称 为 面向 对 象 的 程序 设计 方法 。 

对 象 可 泛 指 客观 世界 中 的 任何 事物 , 既 可 以 是 客观 世界 中 具体 的 一 个 物体 ,例如 一 个 学 
生 、 一 只 小 狗 , 也 可 以 指 客观 世界 中 的 一 次 活动 。 面 向 对 象 的 设计 方法 把 对 象 看 成 研究 的 基 
本 单位 。 

3. 类 的 概念 

类 (class) 是 对 象 的 模板 ,是 对 一 组 相同 对 象 的 基本 属性 和 方法 的 描述 。 为 了 减少 程序 
设计 中 创建 对 象 的 重复 性 劳动 ,系统 创造 了 许多 关于 对 象 的 模板 ( 即 许多 内 置 的 类 )。 这 样 
当 人 们 创建 一 个 新 对 象 时 就 不 需要 从 起 始点 创建 这 个 对 象 ,而 是 可 以 根据 某 个 相似 模板 建 
立新 对 象 , 然 后 再 对 新 对 象 的 某 些 属性 ,方法 加 以 修订 。 

因此 ,类 是 由 所 有 相似 对 象 的 状态 和 方法 构成 的 模板 ,对 提高 程序 的 代码 重用 性 和 系统 
设计 效率 都 非常 重要 。 

4. 面向 对 象 方法 的 技术 特点 

传统 的 结构 化 程序 设计 把 功能 作为 系统 的 基本 组 成 单位 ,在 设计 过 程 中 注重 对 系统 功 
能 的 模拟 。 而 面向 对 象 的 设计 方法 则 把 对 象 作 为 程序 的 基本 组 成 单位 ,对 象 中 既 要 包括 对 
对 象 状态 的 描述 ,还 要 包括 描述 对 象 行为 的 大 量程 序 代 码 。 设 计 过 程 中 需要 通过 对 对 象 及 
其 关系 的 模拟 ,最 终 来 实现 系统 功能 。 

面向 对 象 的 方法 主要 具有 以 下 特点 。 

(1) 封装 性 。 封 装 性 是 指 对 象 把 状态 和 方法 封装 在 一 个 整体 中 , 它 突破 了 传统 程序 中 
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数据 和 代码 分 离 的 处 理 方式 。 把 对 象 的 动态 属性 也 看 成 对 象 自 身 的 一 部 分 ,与 静态 属性 封 
装 在 一 起 。 

(2) 抽象 性 。 由 于 对 象 是 对 客观 事物 的 抽象 。 类 是 对 象 的 模板 ,是 对 具体 对 象 的 抽象 ， 
类 抽象 并 封装 了 一 组 相似 对 象 的 所 有 属性 和 方法 。 因 此 面向 对 象 的 方法 具有 很 强 的 抽 
象 性 。 

(3) 继承 性 。 在 面向 对 象 的 设计 中 ,对 象 由 类 生成 ,新 对 象 自动 具备 类 的 所 有 状态 和 方 
法 。 另 一 方面 ,类 还 可 以 派生 出 子 类 , 子 类 可 以 自动 继承 父 类 的 属性 和 方法 。 这 就 是 面向 对 
象 程序 设计 的 继承 性 思想 。 正 是 继承 性 ,使 得 面向 对 象 的 开发 变 得 简单 ,复杂 对 象 的 创建 过 
程 变 成 对 相似 对 象 的 修补 过 程 , 极 大 地 提高 了 开发 效率 ,提高 了 软件 的 可 重用 率 。 

(4) 多 态 性 。 对 象 间 可 以 通过 消息 建立 动态 连接 ,实现 对 象 间 的 联系 。 同 一 消息 发 送 
给 不 同 的 对 象 能 够 引起 不 同 的 操作 。 对 象 还 能 够 根据 参数 的 类 别 和 性 质 , 分 别 执行 不 同 的 
操作 ,这 也 是 对 象 多 态 性 的 表现 形式 。 动 态 连 编 技术 的 使 用 , 极 大 限度 地 提高 了 程序 的 灵 
活性 。 

总 之 ,面向 对 象 的 设计 方法 更 符合 人 们 认识 世界 的 思路 ; 面向 对 象 的 继承 性 极 大 地 提 
高 了 代码 的 可 重用 性 ; 面向 对 象 的 封装 性 提高 了 系统 的 可 维护 性 和 可 扩展 性 ; 面向 对 象 的 
多 态 性 使 得 系统 的 灵活 性 有 了 很 大 的 提高 。 面 向 对 象 的 方法 在 当前 信息 系统 和 动态 网 站 的 
开发 中 越 来 越 受 到 重视 ,特别 是 .NET 框架 和 JSP 等 新 型 的 信息 系统 开发 工具 的 出 现 , 为 面 
向 对 象 方法 的 应 用 开辟 了 广阔 天 地 。 


2.3.2 定义 类 的 基本 方法 


1. 定义 类 的 基本 思路 
ASP.NET 的 底层 全 部 是 用 类 来 实现 的 。 无 论 是 界面 上 的 控件 ,还 是 数据 类 型 ,甚至 每 
一 个 Web 窗 体 都 会 构成 一 个 类 (class) 。 由 于 面向 对 象 的 程序 设计 中 对 象 具有 封装 性 ,用 户 
只 需要 知道 某 个 类 对 外 的 属性 和 方法 ,不 需要 知道 类 的 内 部 到 底 是 如 何 工作 的 ,就 可 以 操作 
该 类 派生 的 对 象 。 这 一 思路 保证 了 面向 对 象 程 序 设计 的 高 效 性 。 
在 ASP.NET 3.5 页 面 对 应 的 类 包含 在 相应 的 aspx. cs 文件 中 ,前 面 的 几 个 案例 已 经 说 
明了 这 一 点 。 而 用 户 根据 需要 自 定义 的 类 应 该 存放 在 App_Code 文件 夹 下 。 
1) 定义 类 的 语法 格式 
创建 一 个 新 class 的 语法 格式 如 下 : 
[修饰 符 ] class 类 名 称 { 
[定义 成 员 变量 ; ] 
[定义 类 的 构造 函数 ;] 
[定义 类 的 setter 与 getter 函数 ;] 
[定义 类 的 其 他 操作 函数 ;] 
} 
2) 对 类 定义 中 相关 信息 的 说 明 
所 谓 类 的 修饰 符 , 主 要 有 访问 范围 修饰 符 .abstract、static、partial 和 sealed。 其 中 ,访问 
范围 修饰 符 主要 包括 public、protected 、private 和 internal 等 形态 。 而 abstract 修饰 符 表示 
此 类 是 个 抽象 类 ,其 中 含有 抽象 方法 ,不 能 直接 派生 对 象 ， 以 static 修饰 的 类 为 静态 类 ,不 
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能 直接 以 new 创建 其 对 象 ,但 可 以 直接 访问 其 中 的 数据 和 方法 ; 以 partial 修饰 的 类 是 分 布 
式 类 ,表示 这 个 类 的 定义 可 能 被 分 割 到 多 个 源 文件 中 ,所 有 的 Web 窗 体 对 应 的 类 都 使 用 了 
此 修饰 符 ; 以 sealed 修饰 的 类 是 密封 类 ,该 类 不 能 被 其 他 类 继承 。 

所 谓 成 员 变 量 , 是 指 只 属于 类 ,而 不 属于 任何 一 个 函数 (方法 ) 的 变量 。 对 于 成 员 变 量 ， 
可 以 使 用 访问 范围 修饰 符 对 其 作用 域 进行 设置 。 

面向 对 象 程序 设计 中 创建 类 的 目的 是 生成 对 象 ,并 利用 对 象 实现 特定 的 功能 。 人 们 在 
利用 “new 类 名 ();? 语 名 创建 对 象 时 ,系统 会 自动 运行 一 个 函数 名 与 类 名 完全 相同 的 函数 
以 实现 创建 对 象 的 工作 ,这 个 函数 不 能 被 其 他 程序 调用 ,只 能 在 创建 对 象 时 被 系统 自动 调 
用 , 它 被 称 为 构造 函数 。 一 个 类 中 可 以 有 多 个 参数 不 同 的 构造 函数 ,以 适应 产生 对 象 的 需 
要 。 在 构造 函数 的 定义 中 ,不 允许 有 返回 值 ,也 不 能 规定 函数 的 数据 类 型 。 但 是 ,为 保证 创 
建 对 象 时 能 够 顺利 地 调用 构造 函数 ,对 构造 函数 一 般 声 明 为 public 形式 。 

为 了 保障 对 象 的 封装 性 ,避免 外 部 程序 对 对 象 的 成 员 变量 直接 操作 ,一 般 在 定义 类 时 需 
要 定义 一 系列 的 setter 和 getter 函数 。 其 中 setter 函数 负责 对 成 员 变 量 值 进行 修改 ,而 
getter 函数 则 负责 读 取 成 员 变 量 的 值 。 如 果 一 个 类 没有 提供 某 成 员 变量 的 setter 函数 , 则 
认为 这 个 成 员 变 量 是 只 读 的 。 

为 了 实现 特定 的 要 求 , 除 上 述 函 数 外 ,开发 者 还 可 以 根据 需求 定义 其 他 的 函数 。 

注意 ; 定义 在 类 中 的 函数 也 叫 方法 。 

3) 变量 作用 域 与 访问 修饰 符 的 作用 

C# 中 没有 全 局 变量 ,定义 在 类 层次 下 的 变量 是 成 员 变量 ,其 作用 域 由 访问 范围 修饰 符 
控制 。 定 义 在 方法 (函数 ) 内 但 不 属于 程序 语句 块 的 变量 , 称 为 局 部 变量 ,不 需要 用 访问 范围 
修饰 符 控制 ,其 作用 范围 就 是 定义 它 的 函数 块 。 定 义 在 语句 块 内 部 的 变量 ,属于 块 变量 ,其 
作用 域 就 是 定义 它 的 语句 块 。 对 于 块 变量 来 讲 , 当 程序 执行 完 定义 它 的 语句 块 后 ,该 变量 就 
会 被 系统 回收 。 
public, 表 示 被 修饰 的 变量 或 类 是 公共 类 型 ,可 以 不 受 限制 地 被 访问 。 
。 private, 表 示 被 修饰 的 变量 是 私有 类 型 , 带 有 此 修饰 符 的 变量 只 能 应 用 在 定义 它 的 
类 中 ,不 能 被 其 他 的 类 直接 访问 。 
protected ,表示 被 修饰 的 变量 是 保护 类 型 , 带 有 此 修饰 符 的 变量 可 以 被 定义 它 的 类 
和 它 的 所 有 子 类 访问 。 

2. 定义 类 的 具体 案例 

下 面 的 例子 定义 了 一 个 学 生 类 ,其 成 员 变 量 有 姓名 性 别 \ 年 龄 ,成 绩 1\ 成 绩 2\ 成 绩 3。 
然后 类 中 定义 了 两 个 构造 函数 ,若干 个 setter 方法 和 getter 方法 ,以 适应 不 同 的 需要 。 另 
外 ,这 个 类 还 定义 了 一 个 获取 学 生平 均 成 绩 的 方法 getpj。 

1) 创建 Student 类 

利用 MyTest2 的 解决 方案 管理 器 ,为 项 目 MyTest2 执行 [添加 >【 新 建 项 】, 接 着 选择 
【类 】 ,命名 为 MyClass. cs 文件 。 然 后 在 编辑 状态 中 输入 以 下 的 类 定义 代码 ,如 图 2-28 
所 示 。 

2) 以 Web 窗 体 调用 Student 类 

利用 MyTest2 的 解决 方案 管理 器 ,为 项 目 MyTest2 执行 [添加 】>【 新 建 项 】, 接 着 选择 
“Web 窗 体 ”, 命 名 为 stugl. aspx 文件 ,在 其 设计 视图 下 设计 出 如 图 2-29 所 示 界 面 。 
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using System; 

using System. Data; 

using System. Configuration; 

using System. Ling; 

using System. Web; 

using System. Web. Security; 

using System. Web. UI; 

using System. Web. UI. HtmlControls; 
using System. Web. UI. WebControls; 
using System. Web. UI. WebControls. WebParts; 
using System. Xml. Ling; 


namespace MyTest2{ 
public class Student { // 定 义 一 个 名 字 为 Student 的 类 
private String xm, xb; // 定 义 成 员 变量 姓名 ,性 别 
private int age, scol, sco2, sco3; // 定 义 年 龄 ,成 绩 1, 成 绩 2, 成 绩 3 


public Student() // 无 参数 的 构造 函数 


xm= xb = ""; age = 21; 
scol = sco2 = sco3 = 0; avgsco = 0; 

} 

public Student (String xm, String xb, int age, int scol, int sco2, int sco3){ 

// 定 义 有 参数 的 构造 函数 ,构造 函数 重 载 

this.xm = xm; this.xb = xb; this.age = age; 
this. scol = scol; this. sco2 = sco2; this.sco3 = sco3; 

} 

public String sxm { // 姓 名 的 setter 与 getter 函数 
get { return xm; } 
set { this.xm = value; } 

} 

public String sxb { // 性 别 的 setter 与 getter 函数 
get { return xb; } 
set { this.xb = value; } 

} 

public int sscol { // 成 绩 1 的 setter 与 getter 函数 
get { return scol; } 
set { this. scol = value; } 

} 

public int ssco2 { // 成 绩 2 的 setter 与 getter 函数 
get { return sco2; } 
set { this. sco2 = value; } 

} 

public int ssco3 { // 成 绩 3 的 setter 与 getter 函数 
get { return sco3; } 
set { this. sco3 = value; } 


} 
public float getpj() { // 定 义 了 一 个 求学 生成 绩 平均 值 的 普通 函数 
float xx = (float)(scol + sco2 + sco3) /3; 
return xx; 
} 
} 


图 2-28 创建 Student 类 的 代码 图 
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学 生 信息 管理 
学 生 姓名 : 学 生性 别 : [ 友 可 学 生年 龄 : | 
一 科 成 绩 : | 第 二 科 成 绩 : 第 三 科 成 绩 : | 


状 到 


输入 结果 : 


画 
[1 


图 2-29 设计 “学 生 信息 管理 ”界面 图 


分 别 命名 文本 框 控件 的 ID 为 txtXm、txtAge、txtScl、txtSc2、txtSc3, 命 名 下 拉 式 列表 
框 控件 的 ID 为 xsxb, 两 个 标签 控件 的 名 称 为 Ll 和 L2, 按 钮 控件 的 ID 为 check,Text 属性 
为 “检测 ”。 

双击 “检测 ”按钮 ,进入 到 stugl. aspx. cs 的 编辑 状态 ,为 check 按钮 的 Click 编写 处 理 代 
码 ,程序 代码 如 图 2-30 所 示 。 


14 | namespace MyTest2 { 

15 | public partial class WebForm2 : System. Web. UI. Page { 

16 Student stu; 

1 protected void Page_Load(object sender, EventArgs e){ 


18 if(!IsPostBack) stu = new Student(); 

19| } 

20 protected void check_Click(object sender, EventArgs e){ 
21 String sss = ""; // 定 义 局 部 变量 sss; 
22 stu. sxm = txtXm.Text.Trim(); 


23 stu. sxb = xsxb.SelectedValue.ToString(); 
24 stu. sscol = Convert.ToInt32(txtScl.Text); 


25 stu. ssco2 = Convert.ToInt32(txtSc2. Text); 
26 stu. ssco3 = Convert.ToInt32(txtSc3. Text); 
27 sss = stu.sxm + "" + stu.sxb + "" + stu.sscol.ToString() + " "; 


28 sss= sss + stu. ssco2. ToString() +" "+ stu. ssco3. ToString(); 
29 Ll.Text = sss; 
30 L2.Text = stu.getpj().ToString(); 


图 2-30 学 生 信息 管理 的 C# 代 码 


为 了 体现 Web 窗 体 对 外 部 定义 的 类 的 调用 ,在 如 图 2-30 所 示 的 代码 中 实现 了 对 
Student 类 的 应 用 。 

在 这 个 WebForm2 类 中 ,首先 定义 了 一 个 Student 类 型 的 成 员 变量 stu, 以 便 stu 作用 
于 当前 的 整个 类 WebForm2。 为 保证 只 有 第 一 次 加 载 此 页 面 时 才 创 建 stu 对 象 ,本 例 中 使 
用 了 一 个 基本 的 判定 语句 “if(!1IsPostBack)”, 即 如 果 不 是 从 其 他 页 面 后 退回 来 的 ,就 执行 
“stu=new Student(); ”的 语句 ,来 创建 一 个 新 的 stu 对 象 。 这 种 方式 避免 了 重复 创建 stu 
对 象 , 具 有 较 高 的 实用 价值 。 

在 check_Click 方法 中 ,首先 利用 Student 的 setter 方法 把 文本 框 中 输入 的 数据 更 新 到 
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stu 对 象 中 ,然后 利用 Student 的 getter 方法 和 求 平均 值 的 方法 (getpj()) 把 stu 对 象 中 的 数 
据 显示 出 来 。 希 望 通过 本 例 , 大 家 能 够 学 会 设计 C# 的 类 ,并 熟练 地 对 基于 新 类 的 对 象 进行 
赋值 和 提取 数据 的 操作 。 

注意 : 在 面向 对 象 的 程序 设计 中 ,其 他 类 一 般 不 直接 对 类 中 的 成 员 变 量 进行 存 取 操作 ， 
而 是 通过 该 类 自身 提供 的 setter 和 getter 函数 实现 这 一 功能 。 这 一 思路 ,保证 了 对 对 象 数 
据 存 取 的 合法 性 和 准确 性 ,进而 保证 了 对 象 的 封装 性 和 安全 性 。 


2.3.3 字符 串 类 的 应 用 


几乎 任何 一 个 项 目 都 离 不 开 对 字符 串 的 处 理 ,项 目的 安全 性 与 字符 串 的 处 理 也 密切 相 
关 , 因 为 大 多 数 的 系统 漏洞 都 是 由 字符 缓冲 区 的 溢出 引发 的 。 为 此 ,C# 专 门 提 供 了 两 个 
类 ,用 于 支持 字符 串 处 理 。 

1. String 类 与 string 类 型 

1) 定义 字符 串 型 数据 

定义 字符 串 型 数据 使 用 保留 字 string, 而 定义 字符 串 对 象 使 用 保留 字 String。 由 于 
string 型 数据 可 以 自动 转化 为 String 对 象 。 因 此 在 具体 使 用 中 ,对 二 者 几乎 不 做 区 分 。 

定义 字符 串 变量 非常 简单 ,常见 的 方式 为 :“String 变量 名 ; ?或 者 "String 变量 名 = 
值 ”"。 例 如 : 


String xm = "Liping"; 


就 表示 定义 一 个 字符 串 对 象 xm, 并 赋予 初 值 *Liping”。 

2) 字符 串 转 义 字符 

在 传统 的 C 语言 中 ,为 了 在 字符 串 中 表示 不 可 打印 的 特殊 字符 (如 Enter 键 .换行 键 、 空 
格 键 Tab 键 ) ,专门 规定 了 一 个 转 义 字符 “\”。 采 取 了 以 转 义 字符 为 前 导 表示 特定 字符 的 方 
式 。 例 如 NAn' 不 表示 字符 “n? 而 是 表示 回 车 符 , 以 Nt 表示 制 表 符 Tab。 因 此 要 真正 地 表示 字 
符 “\”, 则 需要 使 用 “\\”。 即 如 果 要 表示 路 径 *C:\Ma\Document. doc” 就 必须 使 用 *C:\\Ma 
\\Document. doc”。 

采用 转 义 字符 解决 了 特殊 字符 的 表示 问题 ,但 也 使 文件 路 径 的 描述 显得 烦琐 。 为 此 ,在 
C# 中 又 专门 添加 了 一 个 取消 转 义 字符 的 记号 *“@”。C# 规 定 ,凡是 以 “@” 引 导 的 字符 串 中 
不 包含 转 义 字符 。 因 此 ,对 于 文件 路 径 ,可 以 使 用 如 下 描述 形式 ， 


String wjm= @"C:\Ma\Document. doc" 。 


如 果 要 获取 字符 串 中 的 某 个 字母 ,可 以 把 字符 串 看 做 一 个 字符 数组 ,直接 使 用 数组 形 
式 。 例如: 


char ch= wjm[1]; 


表示 要 获取 字符 串 wjm 中 的 第 2 个 字符 ,对 于 前 面 的 例子 ,结果 得 到 “:”。 注 意 ,字符 序号 
从 0 开始 。 

2. 字符 串 参数 与 输出 格式 

1) 字符 串 参数 

在 字符 串 处 理 中 ,经 常 需要 使 用 "字符 串 常 量 十 变量 内 容 ” 的 格式 输出 数据 。 例 如 把 人 
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名 "“ 张 三 ?存储 在 变量 xm 中 ,需要 输出 “我 的 姓名 是 张 三 ”, 当 人 名 变 成 “ 李 四 ” 时 , 则 需要 输 
出 “我 的 姓名 是 李 四 ”。 也 就 是 说 ,“ 张 三 ”和 “ 李 四 ” 是 输入 字符 串 的 参数 。 为 此 可 以 使 用 以 
下 格式 合成 字符 串 ,或 者 直接 输出 字符 串 : 

String newStr = String. Format( "我 的 姓名 是 {0}!", xm); 

这 里 的 {0} 表 示 字 符 串 的 第 0 个 参数 。 在 输出 或 者 合成 时 ,会 用 字符 串 后 面 紧 随 的 xm 
变量 值 取代 。 再 如 : 

String newStr = String. Format( "我 的 姓名 是 {0}! ,我 爱好 {1}.", xm,aihao); 


系统 会 用 xm 的 值 取 代 {0) ,用 aihao 的 值 取代 参数 {1}。 

2) 字符 串 输出 格式 

由 于 多 种 类 型 的 数据 都 可 以 作为 字符 串 输出 的 参数 ,可 以 通过 设置 这 些 参数 的 输出 格 
式 , 使 其 符合 用 户 的 要 求 。 对 这 些 参数 实施 格式 设置 的 规范 是 ， 


{ 参 数 序号 [, 参 数 最 小 宽度 ] :[ 参 数 格式 符号 ]} 


针对 DateTime 类 型 的 输出 格式 符 如 表 2-1 所 示 ; 针对 数值 类 型 数据 的 输出 格式 符 如 
表 2-2 所 示 。 


表 2-1 针对 DateTime 类 型 的 输出 格式 符 


格式 符 中 文 名 称 含 义 
d 短 日 期 模式 
D 长 日 期 模式 
短 时 间 模 式 
是 长 时 间 模 式 
f 完整 日 期 /时 间 模 式 显示 长 日 期 和 短 时 间 模 式 的 组 合 , 由 空格 分 隔 
F 完整 日 期 /时 间 模 式 显示 长 日 期 与 长 时 间 模 式 的 组 合 
g 常规 日 期 /时 间 模式 显示 短 日 期 和 短 时 间 模 式 的 组 合 
G 常规 日 期 /时 间 模式 显示 常规 日 期 和 长 时 间 模式 的 组 合 


表 2-2 针对 数值 类 型 数据 的 输出 格式 符 


格 式 符 中 文 名 称 含义 

C 或 c 货币 格式 数字 转换 为 表示 货币 金额 的 字符 串 

D 或 d 整 型 十 进 制 格式 数字 转换 为 十 进 制 数字 的 字符 串 ,以 精度 说 明 符 指示 结 
果 字 符 串 中 所 需 的 最 少数 字 个 数 

E 或 e 科学 计数 法 (指数 ) 数字 转换 为 “一 d. ddd…E 十 ddd? 或 “一 d. ddd…e 十 ddd" 形 
式 的 字符 串 

F 或 f 固定 点 数字 转换 为 “一 ddd. ddd…” 形 式 的 字符 串 ,以 精度 说 明 符 
指示 所 需 的 小 数位 数 

G 或 g 常规 


例如 ,希望 第 0 个 参数 按照 短 日 期 格式 输出 , 则 可 以 表示 为 : {0:d}。 和 希望 第 1 个 参数 
按照 7 位 整数 的 格式 输出 ,不 够 7 位 则 在 左边 用 空格 填充 , 则 可 以 表示 为 : {1,7:D})。 
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3. 常见 的 字符 串 操 作 方法 
1) 生成 字符 串 


String str = "我 的 姓名 是 老 马 !"; 
String str = new String(' 我 ',5);  // 结 果 为 连续 5 个 "我 "; 


2) 比较 两 个 字符 串 
String. Compare( strA, strB) ; // 比 较 两 个 字符 串 的 大 小 ,返回 数值 型 结果 : 0, - 1,1; 
3) 比较 两 个 字符 串 是 否 相等 


String. Equals( strA, strB) // 返 回 bool 型 结果 ; 
或 者 
strA== strB 
4) 查找 指定 字符 串 在 字符 串 中 出 现 的 位 置 
strA. IndexOf ( 子 字符 串 ) // 返 回 子 字符 串 在 strA 中 的 位 置 ,注意 位 置 从 0 起 点 ， 
5) 在 一 个 字符 串 的 指定 位 置 插入 指定 的 字符 串 
strA. Insert(2, 子 字符 串 ) // 把 子 字符 串 插 入 到 字符 串 strA 的 位 置 2 之 处 ; 


6) 从 字符 串 中 截取 出 一 部 分 
strA. Substring( 位 置 ,长 度 ) // 从 字符 串 stra 中 指定 位 置 截取 指定 长 度 的 子 串 
7) 对 字符 串 进行 大 小 写 转换 


strA. ToUpper( ); // 把 字符 串 stra 转化 为 大 写 
strA. ToLower( ); // 把 字符 串 stra 转化 为 小 写 
8) 去 掉 字 符 串 前 后 的 空格 

strA. Trim( ); // 去 掉 字 符 串 前 后 的 空格 


4. StringBuilder 类 

1) String 对 象 的 局 限 性 

String 对 象 在 字符 串 更 新 中 存在 着 局 限 性 ,在 每 次 重新 赋值 时 都 会 重新 分 配 内 存 空间 。 
如 果 在 应 用 程序 的 循环 体 中 大 量 重复 地 对 String 对 象 赋值 ,可 能 会 致使 系统 内 存 不 足 , 导 
致 系统 崩溃 。 为 此 ,建议 使 用 StringBuilder 类 。 

2) StringBuilder 类 

StringBuilder 类 位 于 System. Text 名 称 空间 下 ,使 用 StringBuilder 类 每 次 重新 生成 新 
字符 串 时 不 是 再 生成 一 个 新 实例 ,而 是 直接 在 原来 字符 串 占用 的 内 存 空 间 上 进行 处 理 ,动态 
地 进行 计算 机 内 存 管理 。 例 如 : 


StringBuilder strB = new StringBuilder(); 
strB. Append( 新 字符 串 ); 


上 述 语句 的 功能 是 把 新 字符 串 附加 到 strB 中 。 
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5. 数据 类 型 转换 

数据 类 型 转换 是 程序 设计 中 非常 常用 的 一 种 功能 ,在 C# 中 实现 数据 类 型 转换 ,主要 有 
以 下 两 种 思路 : 

。C# 提 供 了 一 个 非常 有 效 的 类 Convert, 它 提供 了 多 种 类 型 之 间 的 转换 。 

。 基 本 类 型 可 以 自动 地 转化 为 基本 类 ,利用 基本 类 提供 的 ToString() 方 法 ,可 以 实现 

从 其 他 类 型 向 字符 串 类 型 的 转换 。 

1) 字符 串 型 转化 为 整 型 

利用 Convert. ToInt32 把 字符 串 型 数据 转化 为 整 型 。 例 如 ,前 例 (计算 器 ) 设 计 中 把 输 
入 的 数据 转换 为 整 型 


int xl = Convert. ToInt32(T1. Text); 


2) 字符 串 型 转化 为 双 精 度 型 
利用 Convert. ToDouble 把 字符 串 型 数据 转化 为 双 精 度 型 数值 。 例 如 ,可 以 把 前 例 ( 计 
算 器 ) 设 计 中 输入 的 字符 串 数据 转换 为 双 精度 数值 : 


double yy = Convert. ToDouble(T1.Text) ; 


3) 字符 串 型 转换 为 日 期 时 间 型 
利用 Convert. ToDateTime 把 字符 串 型 数据 转化 为 日 期 时 间 型 ,例如 : 


DateTime dt = Convert. ToDateTime(T1. Text); 


4) 其 他 类 型 转化 为 字符 串 型 
把 各 种 类 型 转换 为 字符 串 型 有 比较 统一 的 两 种 方法 。 其 一 是 利用 Convert 类 ,其 二 是 
利用 基本 类 提供 的 ToString() 方 法 。 例 如 : 


int xx = 88; 
String sl = xx. ToString(); 


或 者 


String s2 = Convert. ToString(xx); 


@.4 ASP. NET Web 项 目的 结构 


通过 前 面 一 段 时 间 的 学 习 , 我 们 对 aspx 动态 网 页 的 整体 结构 有 了 一 个 简单 的 认识 。 为 
了 系统 地 掌握 这 些 知识 ,需要 我 们 对 一 个 Web 项 目的 整体 结构 进行 较为 详细 的 分 析 。 

1. ASP. NET 项 目的 基本 构成 

在 VS2008 下 ,任意 打开 一 个 ASP.NET 的 Web 项 目 ,打开 其 “解决 方案 资源 管理 器 ” 
可 以 看 到 VS2008 对 一 个 Web 项 目的 组 织 , 如 图 2-31 所 示 。 

从 图 中 可 以 看 出 ,在 解决 方案 中 主要 包括 了 以 下 几 类 内 容 : 文件 夹 Properties 文件 夹 
“引用 ”文件 夹 App_Data ,若干 个 aspx 文档 。 有 的 解决 方案 中 还 包括 CSS 样式 文件 、 
aspx. cs 文档 (C# ) 程 序 文件 。 在 有 的 版 本 下 ,还 有 一 个 App_Code 文 件 夹 。 


76 


动态 网 站 设计 与 开发 (ASP. NET 版 ) 


1) 文件 夹 Properties 


Properties 文件 夹 定义 本 程序 集 的 属性 。 在 此 文件 夹 中 通常 只 有 一 个 AssemblyInfo. cs 类 


WT Xx| 
局 | 吕 固 | 及 


文件 ,用 于 保存 程序 集 的 信息 ,如 名 称 ,版 本 
等 ,这 些 信息 一 般 与 项 目 属性 面板 中 的 数据 


园 解 六 方案 "MyTest2" (1 个 项 目 


固 suglaspxcs 
固 suglaspxdesignercs 
总 webconfg 
由 - 国 week for.aspx 
由 国 zhishuaspx 


图 2-31 ASP.NET 项 目的 “解决 方案 资源 管理 器 ” 


对 应 ,不 需要 手动 编写 。 

2) 文件 夹 “ 引 用 ” 

文件 夹 “ 引 用 ”是 关于 本 项 目的 外 部 引 
用 信息 的 集合 。 只 要 右 击 解决 方案 资源 管 
理 器 中 的 【引用 】, 然 后 选择 【添加 引用 了 , 即 
可 打开 【添加 引用 对 话 框 ,把 其 他 项 目 或 系 
统 预 置 的 一 些 组 件 链接 到 本 项 目 中 ,以 供 本 
项 目 使 用 。 

3) 文件 夹 App_Data 

文件 夹 App_Data 关于 本 项 目的 数据 


存储 信息 ,此 文件 夹 主要 用 于 存储 本 项 目 用 到 的 数据 库 文件 。 如 果 开 发 者 使 用 系统 内 置 的 
登录 组 件 (Login) ,系统 将 会 在 App_Data 文件 夹 下 自动 地 创建 一 个 数据 库 ,以 此 数据 库 保 


存 与 这 个 登录 组 件 相关 的 数据 。 
4) CSS 样式 文件 


在 动态 网 页 设计 中 ,必须 要 进行 规范 文本 格式 、 开 展 页 面 布 局 等 操作 ,而 这 些 操作 都 是 
与 格式 相关 的 信息 。 对 于 一 个 大 型 网 站 来 讲 , 为 保证 所 有 页 面具 有 相同 的 风格 ,并 便于 对 所 
有 页 面 格式 进行 统一 的 格式 管理 ,采用 了 CSS 样式 文件 技术 。 即 把 关于 文本 格式 、 页 面 布 
局 等 格式 规范 统一 保存 在 一 个 CSS 样式 文件 中 。 这 个 文件 是 样式 的 集合 ,可 供 所 有 的 网 页 


引用 。 
5) aspx. cs 文件 与 aspx 文件 


这 两 类 文件 共同 协作 实现 动态 网 页 ,其 中 aspx 文件 主要 存储 HTML 控制 符 、 文 本 内 
容 、 图 片 链接 等 信息 ,而 aspx. cs 文件 是 C# 代码 的 源 文 件 ,主要 负责 对 网 页 中 动态 数据 的 


处 理 。 


另外 ,项 目的 专用 class 定义 文件 也 以 cs 作为 扩展 名 。 


6) sln 文 件 


sln 文件 , 即 解决 方案 文件 (Visual Studio. Solution) ,是 在 开发 环境 中 使 用 的 解决 方案 
文件 , 它 通过 为 环境 提供 对 项 目 、 项 目 项 和 解决 方案 项 在 磁盘 上 位 置 的 引用 ,将 它们 组 织 到 
解决 方案 中 。 此 文件 通常 存储 在 项 目的 父 目录 中 。 

要 打开 一 个 项 目 文件 ,就 是 打开 其 解决 方案 文件 。 例 如 ,使 用 [文件 >【 打 开 】>【 项 目 / 


解决 方案 】 ,然后 选择 相应 的 sln 文件 即 可 。 
7) 文件 夹 App_Code 


顾名思义 ,文件 夹 App_Code 存储 项 目的 代码 文件 ,通常 用 于 保存 项 目的 类 文件 、C# 


的 源 程序 文档 。 
8) 其 他 文件 夹 


在 一 个 ASP.NET 的 Web 项 目下 ,通常 还 能 够 看 到 其 他 几 个 文件 夹 : bin 和 obj。 其 
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gs 文件 夹 用 于 存放 编译 后 的 目标 文件 ; bin 文件 夹 用 于 存放 最 终 的 结果 文件 ,一 种 能 够 
行 于 CLR 环境 下 的 伪 码 文件 。 
如 果 要 发 布 一 个 网 站 ,通常 不 需要 包含 扩展 名 为 cs 的 C# 源 程序 ,而 是 必须 包括 bin 文 
件 夹 (其 中 包括 了 本 项 目 中 由 VS2008 负责 编译 好 的 、 不 能 被 人 类 直接 阅读 的 全 部 伪 码 
文件 ) 。 
2. Web 窗 体 的 文档 结构 
在 ASP.NET 的 Web 应 用 程序 开发 中 ,动态 网 页 文件 (Web 窗 体 ) 的 组 建 是 中 心 任务 。 
任何 一 个 Web 窗 体 都 至 少 包括 两 个 文件 : 文件 名 . aspx、 文 件 名 . aspx. cs。 
下 面 将 通过 “学 生 信 息 管理 "Web 窗 体 (stugl) 说 明 一 般 Web 窗 体 的 文档 结构 。 
) aspx 文件 的 结构 
已 知 “ 学 生 信息 管理 ” 窗 体 的 界面 设计 如 图 2-29 所 示 ,对 应 的 代码 如 图 2-32 所 示 。 


1 Ch Paee Langusee= CH" Kutofvenilireup= "true" Codehehind"stuel. aspx, cs™ Irherits="NyTert2 Webp | 
2 《IDOCTYPE html PUBLIC "-//W3C//DTD XHINL 1.0 Transitional//EN" "http: //www.w3. org/TR/xhtmll/DTD, ^ 
3 日 中 tml xmlns=" "http: Hw. w3. org/ 1999/xhtnl" > 门 


4 外 人 head runat="seryer > 


5 《title> 天 标题 页 C/title> 

6 Cstyle type="text/css"> 

了 stylel { text-align， center; font-size: x-large; font-weight: bold; 

8 

9 style3 { text-align: center; font-size: large; font-weight: bold; 3- 
10 了 
11 style> Chead> 
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ody> 
13 | 刀 class="style1"》 学生 信息 管理 p> 
14 唱 《form id="forml" runat="server"》 
《pclass="style3"》 学 生 姓名 : 《asp:TextBox ID= "txt runat=" server")C/asp: TextBox> 
Danbsp; 学 生性 别 ; 《asp: DropDownList ID="xsxb" runat="server"》 


17 《asp:ListItem) 男 (fasp:ListItem> Casp:ListItem) 女 Cfasp:ListIten> 

18 /asp: DropDownList> 

19 中 anbsp: 学 生年 龄 : Casp: TextBox ID="txtAge" runat="server">K/asp:TextBox> /p> 

209 Cp class="style3"> 

21 第 一 科 成 绩 ; 《asp: TextBox ID="txtScl" runat="server" Width="101px">C/asp:TextBox> 
22 第 二 科 成 绩 : 《asp:TextBox ID="txtSc2" runat="server" Width="94px" "fasp: TextBox> 

23 第 三 成 绩 : Kasp; TextBox ID="txtSe3" runat="server" Width="8Bpx">C/asp:TextBox>C/p> 
24 Cp class="style3" > 

25 《asp:Button ID="check" runat="server" onclick="check_Click” Text=" 检 测 " /2Cp> 
26 《pclass="style3"》 输 入 结果 : 《4/p> 

27 Cp class="style3" 《asp:Label ID="L1" runat="server">C/asp:Label> /p> 

28 Cp class="style3">Casp: Label ID="12" runat="server"> /asp:Label>Yp> 

2 pManbsp; YpMXdiv> 

30 Ydiv forn’ 

31t fbody>/html> ~ 


Ls=r I 


图 2-32 学 生 信 息 管理 程序 的 aspx 文件 的 内 容 


上 述 代码 全 部 存储 在 stugl. aspx 文档 中 。 文 件 的 第 1 行 说 明 此 动态 网 页 所 采用 的 计算 
语言 是 C# ,本 网 页 所 对 应 的 C# 源 程序 为 stugl. aspx. cs, 此 网 页 是 项 目 MyTest2 中 的 
一 沾 于 更 面 ， 
第 4 行 至 第 11 行 是 网 页 的 头 文件 ,其 中 <<title 之 和 < 志 /title> 之 间 的 内 容 是 网 页 的 标 
题 ,本 网 页 标题 为 “无 标题 页 ”。 第 6 一 11 行 定 义 了 两 个 样式 ,样式 名 字 分 别 为 stylel 和 
style3。 这 种 样式 既 可 以 直接 放 到 aspx 文件 中 ,也 可 以 存储 在 专用 的 CSS 文件 中 。 
第 12~31 行 是 网 页 的 主体 部 分 ,其 中 的 第 14 一 20 行 定义 了 一 个 运行 于 服务 器 端的 表 
单 (form id 二 forml runat 二 "server")。 在 这 个 表单 内 部 ,有 多 个 服务 器 端 控 件 , 比 如 “过 asp 
TextBox ID="txtXm'" runat 二 "Server" 祖 之 /asp TextBox 这 ”就 是 从 工具 箱 中 拖 动 到 窗 体 
内 的 TextBox 控件 ,其 ID="txtXm" 也 是 通过 窗 体 的 [属性] 面板 修改 后 得 到 的 结果 。 再 比 
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如 “<<asp:Button ID=="check" runat 二 "server" onclick 王 "check_Click" Text = 二" 检测" /二 ” 则 定 
义 了 一 个 ID 为 check, 按 钮 上 面 的 标记 文字 为 “检测 ”的 按钮 ,并 且 为 此 按钮 的 onclick 事件 
指明 了 响应 方法 的 名 称 “check_Click”。 

这 一 案例 清晰 地 展示 了 一 个 aspx 文件 的 基本 结构 。 事 实 上 ,aspx 文件 的 绝 大 多 数 代 
码 都 是 在 主 工作 区 的 设计 视图 下 、 以 可 视 化 的 方法 完成 的 ,其 代码 基本 由 系统 自动 生成 ,不 
需要 开发 人 员 过 多 地 干预 。 

2) aspx. cs 的 结构 

打开 stugl. aspx. cs 文件 ,就 能 够 明白 一 个 aspx. cs 文件 的 基本 构成 了 ,其 结构 如 图 2-33 
所 示 。 


lgusing System; 

2i| using System. Collections; 

:| using System. Configuration; 

4 | using System. Data; 

| using System. Ling; 

‘| using System.Web; 

‘| using System. Web, Security; 

B:| using System. Web, UT; 

9:| using System. Web. UT. HtmlControls; 
[using System. Web. UT. WebControls; 
1:| using System. Web. UT. WebControls. WebParts; 
tusing System, Xml. Ling; 


nanespace NyTest2 
| 
public partial class WebForm2 : System.Web. UI.Page 


Student stu; 
protected void Page Load(object sender, Eventhres e) 


if (lIsPostBack) stu = new Student(); 


protected void check Click(object sender, Eventhres e) 
{ 


String sss = ""; ff 定义 局 部 变 里 sss; 
stu. sxm = txtXm. Text. Trim(); 

stu, sxb = xsxb, SelectedYalue. ToString(); 

stu, sscol = Convert.ToInt32 (txtScl. Text); 

stu. ssco2 = Convert. ToInt32 (txtSc2. Text); 

stu, ssco3 = Convert. ToInt32 (txtSc3. Text); 

sss = stusxm +" "+stusxb+" "+ stusscol.ToStrinel) + " "; 
sss=ssststu. ssco2. ToString +" "+stu ssco3.ToStringO):; 

Ll.Text = sss; 

I2.Text = stu. getpj 0.ToStringO):; 


图 2-33 学 生 信息 管理 程序 的 C# 代 码 


从 图 2-33 可 知 ,第 1 一 12 行 是 一 组 自动 添加 的 using 语句 , 列 人 了 本 程序 要 引入 的 名 称 
空间 。 由 于 VS2008 提供 了 众多 的 class( 类 ) 供 开发 者 使 用 ,这 些 class 被 分 别 存放 在 不 同 的 
名 称 空间 中 。 如 果 开 发 者 需要 引用 某 个 名 称 空间 ,就 需要 用 using 语句 进行 声明 。 

第 14 行 是 个 namespace 语句 ,表示 定义 了 一 个 名 字 为 MyTest2 的 名 称 空间 ,而且 此 名 
称 空间 的 作用 范围 为 第 14 一 38 行 ,表示 本 网 页 的 全 部 C# 代 码 都 被 定义 在 这 个 名 称 空 
间 中 。 

第 16 一 27 行 表示 本 网 页 定义 了 一 个 类 (class), 类 的 名 称 为 WebForm2, 它 继承 于 
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VS2008 系统 的 内 置 类 Page。 这 是 一 个 被 partial 修饰 的 类 ,表示 定义 这 个 类 的 代码 可 以 存 
放 在 多 个 aspx. cs 文件 中 。 

类 WebForm2 中 包括 了 两 个 方法 : 其 一 是 Page_Load ,是 网 页 调和 人 时 直接 执行 的 函数 ， 
在 这 个 函数 中 进行 了 检测 : 如 果 是 首次 调和 这 个 页 面 , 则 创建 一 个 Student 类 对 象 ; 其 二 是 
check_Click ,其 中 包含 了 按钮 check 被 单 击 时 要 执行 的 代码 。 


假 考题 


1. aspx 与 aspx. cs 文件 是 一 种 什么 关系 ? 二 者 通过 什么 语句 联系 在 一 起 ? 

2.C# 语句 具有 什么 特点 ? C# 语 言 中 是 否 区 分 大 小 写字 母 ? 一 个 C# 语句 以 什么 符 
号 作为 语句 结束 符 ? 

3. C# 的 基本 数据 类 型 有 哪些 ? 在 网 站 开发 时 ,分 别 适 应 于 哪些 应 用 范围 ? 

4. C# 标 识 符 的 命名 应 该 遵循 哪些 规则 ? 

5.C# 的 逻辑 运算 符 “ 与 或 非 " 和 位 运算 符 “ 与 或 非 " 有 什么 不 同 ? 

6. C# 的 分 支 控制 语句 主要 有 哪 两 个 ? 基本 的 语法 格式 是 什么 ? 

7. C# 的 循环 控制 语句 主要 有 哪 4 个 ”foreach 语句 有 什么 用 途 ? 

8. 什么 是 对 象 ? 什么 是 方法 ? 什么 是 成 员 变量 和 成 员 函 数 ? 

9. 什么 是 类 ? 类 与 对 象 是 什么 关系 ? 什么 是 继承 ? 

10. 比较 String 与 StringBuilder, 二 者 各 有 什么 优势 ? 

11. 如 何 把 其 他 类 型 的 数据 转化 为 字符 串 型 ? 如 何 把 字符 串 型 数据 转化 为 其 他 类 型 ? 

12. 什么 是 字符 串 参 数 ?如何 设置 字符 串 参 数 的 输入 格式 ? 


仁 机 实 训 是 


启动 VS2008 ,新 增 项 目 Test2 ,然后 在 此 项 目 中 完成 以 下 任务 。 

QO@ 新 建 一 个 窗 体 , 在 此 窗 体 中 添加 TextBox 和 Button 控件 , 当 单 击 Button 时 ,能 够 输 
出 TextBox 中 数值 的 平方 和 立方 。 

@ 新 建 一 个 窗 体 ,在 此 窗 体 中 添加 TextBox、Button 和 Label 控件 , 当 单 击 Button 时 ， 
能 够 把 TextBox 中 数据 的 阶乘 计算 出 来 。 对 于 TextBox 中 数值 小 于 1 或 者 大 于 10 的 情 
况 ,需要 以 弹出 警示 框 的 方式 给 予 提示 “被 计算 阶乘 的 整数 不 能 小 于 1 或 大 于 101”。 


到 


ASP.NET 的 Web 控 件 


学 习 要 点 
本 章 主要 学 习 ASP.NET 标准 控件 和 数据 验证 控件 ,要 求 了 解 ASP.NET 工具 箱 的 组 
成 、 标 准 控件 和 验证 控件 的 基本 属性 和 基本 方法 。 本 章 要 求 重点 关注 以 下 内 容 : 

。 为 Web 窗 体 添加 常见 控件 的 技术 ,设置 控件 属性 的 技术 、 针 对 控件 的 事件 添加 响应 
方法 的 技术 。 

。 Label, Button、 TextBox、DropDownList、RadioButtonList、CheckBoxList 控件 的 使 
用 方法 ; 重点 关注 后 3 个 控件 的 选项 设置 。 

。 窗 体验 证 控件 的 设置 ,重点 关注 其 ControlToVadidate 属性 、Text 属性 与 ErrorMessage 
属性 。 


6.1 .NET 3.5 服务 器 控件 概述 
有 


Web 控件 是 VS2008 开发 工具 为 开发 者 提供 的 重要 工具 。 事 实 上 ,位 于 工具 箱 中 的 
Web 控件 在 本 质 上 都 是 类 (class) ,开发 者 可 以 便利 地 把 这 些 控件 拖 动 到 窗 体 中 ,并 依据 控 
件 的 固有 属性 进行 配置 ,针对 控件 的 操作 事件 编写 方法 ,从 而 完成 开发 。 因 而 学 习 Web 控 
件 的 使 用 ,是 学 习 ASP.NET Web 应 用 程序 开发 的 关键 所 在 。 

从 Web 窗 体 的 工具 箱 来 看 , ASP .NET 控件 有 9 类 ,其 中 
HTML 组 控件 是 传统 的 HTML 网 页 所 使 用 的 控件 ,重点 用 于 解 
决 客户 端 表单 设计 问题 ,不 是 本 节 讨 论 的 内 容 。 下 面 将 从 控件 组 
名 称 的 视角 对 控件 类 别 进 行 简单 的 说 明 。VS2008 的 工具 箱 如 
图 3-1 所 示 。 

(1) “标准 ?控件 应 该 是 Web 程序 开发 的 主要 控件 组 ,包含 了 
Web 程序 开发 中 所 用 到 的 绝 大 多 数 的 交互 式 方式 。 

(2)“ 数 据 ?组 控件 主要 负责 数据 处 理 , 其 中 心 任务 是 建立 与 ”图 3-1 VS2008 工 具 箱 
数据 库 的 连接 并 实现 数据 库 访问 。 

(3)“ 验 证 ?组 控件 负责 数据 输入 验证 , 即 检查 用 户 在 交互 式 表单 中 输入 数据 的 合理 性 ， 
对 于 不 符合 要 求 的 数据 给 予 警示 性 提示 。 

(4)“ 导 航 ? 组 控件 主要 为 网 站 的 组 织 . 构 建 导航 体系 提供 支持 , 主要 提供 了 
SiteMapPath .TreeView 和 Menu 三 个 综合 性 的 控件 。 


第 3 章 “ASP. NET 的 Web 控 件 


(5)“ 登 录 ” 组 控件 主要 负责 以 微 少 编码 的 方式 为 开发 者 提供 登录 和 身份 认证 模块 ,使 
开发 者 可 以 快速 地 构造 网 站 并 建立 系统 登录 与 认证 体系 。 

(6)“AJAX Extensions” 组 控件 通过 “ScriptManager” 和 “UpdatePanel” 控 件 提供 了 对 
Ajax 技术 的 支持 ,使 得 Web 程序 实现 页 面 的 局 部 刷新 成 为 可 能 。 

(7)“ 报 表 ” 组 提供 了 报表 技术 支持 。 


6.; Web 服务 “标准 ”控件 


ASP.NET 3.5 的 标准 控件 提供 了 构造 Web 窗 体 页 面 的 基本 功能 ,这 些 控件 既 具 有 一 
些 公共 的 属性 ,又 根据 自己 的 功能 具备 个 性 化 的 属性 和 方法 。 


3.2.1 标准 控件 的 公共 属性 与 方法 


从 前 面 的 设计 看 ,作为 对 象 标志 的 ID 是 所 有 控件 都 必须 具备 的 属性 ,这 一 属性 值 是 对 
象 的 标识 性 信息 ,是 程序 调用 和 操作 此 代码 的 基础 ,诸如 Text、 Width Height 等 属性 也 广 
泛 地 存在 于 各 个 控件 中 。 另 外 ,应 对 Click 和 Changed 事件 的 方法 在 各 个 控件 中 广泛 具备 。 
关于 标准 控件 中 常见 公共 属性 与 方法 ,如 表 3-1 所 示 。 


表 3-1 标准 控件 的 公共 属性 与 方法 


属性 /方法 名 含 义 属性 /方法 名 含义 

ID 对 象 标识 符 Text 显示 在 对 象 上 的 文本 

Enabled 对 象 的 可 用 性 Visible 对 象 的 可 视 性 

Width 对 象 的 宽度 Height 对 象 的 高 度 

BackColor 对 象 的 背景 色 CssClass 对 象 使 用 的 CSS 类 

Font 对 象 的 字体 BorderWidth 对 象 边框 宽度 

AccessKey 设置 指向 此 对 象 的 快捷 键 Load 对 象 调 入 内 存 时 

Click 对 象 的 单 击 事件 

3.2.2 主要 的 标准 控件 

1. Label 控件 

Label 控件 用 于 在 窗 体 中 显示 文本 型 信息 ,允许 程序 在 服务 器 端 通过 修改 其 Text 值 改 
变 显 示 的 内 容 。 


Label 控件 没有 返回 值 , 但 有 一 个 AssociatedControlID 属性 ,如 果 在 它 的 这 个 属性 中 填 
人 一 个 交互 性 控件 的 ID, 则 会 把 Label 控件 与 这 个 控件 关联 在 一 起 。 在 程序 运行 时 ,当选 
中 Label 控件 时 ,输入 焦点 会 停靠 在 交互 式 控件 上 。 

2. TextBox 控件 

TextBox 控件 是 一 个 文本 框 ,用 于 在 窗 体 中 输入 数据 或 显示 数据 ,数据 类 型 默认 为 字符 
串 型 。 人 允许 程序 在 服务 器 端 通过 修改 其 Text 值 改变 显示 的 内 容 。 

TextBox 的 关键 属性 及 其 含义 如 表 3-2 所 示 。 
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表 3-2 TextBox 的 关键 属性 


属性 ,方法 或 事件 取 和 值 取 值 的 含义 

SingleLine 单行 文本 框 
TextMode MultiLine 多 行文 本 框 

Password 此 文本 框 为 密码 框 , 回 显 信 息 为 指定 字符 
AutoPostBack true 当 光 标 离开 文本 框 时 触发 TextChanged 事件 
Focus() 方 法 设置 此 文本 框 为 输入 焦点 
TextChanged 事件 文本 内 容 被 改变 且 焦 点 离开 文本 框 时 的 方法 
Text 返回 文本 框 中 输入 的 内 容 


3. Button LinkButton 与 ImageButton 控件 

Button .LinkButton 和 ImageButton 都 是 Web 窗 体 的 按钮 控件 ,三 者 的 功能 基本 相同 ， 
只 是 在 外 观 上 有 些 差 别 。Button 就 是 普通 的 Windows 按钮 ,LinkButton 是 呈现 为 超 链接 
形式 的 按钮 ,ImageButton 则 呈现 为 图 像 形式 ,其 图 像 由 ImageUrl 属性 设 定 。 

这 三 个 控件 的 关键 属性 及 其 含义 如 表 3-3 所 示 。 


表 3-3 Button .LinkButton 与 ImageButton 控件 的 关键 属性 及 其 含义 


属性 方法 或 事件 取 和 值 取 值 的 含义 

PostBackUrl 属性 网 址 单 击 按钮 时 发 送 到 的 网 址 

Click 事件 当 鼠 标 单 击 时 触发 ,开始 执行 ASP.NET 代码 
ClientClick 事件 当 鼠 标 单 击 时 触发 ,开始 执行 客户 端 JavaScript 代码 
ImageUrl 属性 图 片 名 指明 ImageButton 按钮 的 显示 图 像 


在 ClientClick 事件 中 ,通常 直接 设置 一 个 简单 JavaScript 语句 ,或 者 设置 一 个 
JavaScript 的 函数 名 称 。 例 如 某 个 按钮 btn 的 功能 是 删除”, 如 果 和 希望 在 真正 地 执行 Click 
事件 实施 删除 功能 前 ,要 求 用 户 对 删除 操作 进行 确认 ,就 可 以 在 aspx 的 源 文档 下 使 用 下 面 
的 语句 

<asp: Button ID = btn Runat = "Server" Text = "删除 " onClick = "btn_Click" onClientClick = 

"return confirm( ' 您 确实 要 删除 这 个 记录 吗 ?') ;"> 

这 里 的 “return confirm()” 语 句 就 是 一 个 运行 在 客户 端的 JavaScript 语句 。 

4. DropDownList 控件 

DropDownList 是 下 拉 式 列表 框 控 件 , 其 作用 是 提供 一 个 下 拉 式 列表 ,并 请 用 户 从 列表 


中 选择 其 中 的 一 项 。 在 下 拉 式 列表 框 对 象 中 ,设置 选项 是 二 
非常 重要 的 任务 。 目 前 可 以 为 下 拉 式 列表 框 提供 选项 的 = 
方法 有 三 种 : 其 一 是 在 [设计 ] 视 图 下 直接 输入 ; 其 二 是 利 a | 

用 程序 代码 添加 ; 其 三 是 直接 把 数据 表 的 某 个 字段 绑 定 到 

下 拉 式 列表 框 对 象 上 。 3 DronDomnlsse tatty 


其 显示 效果 如 图 3.2 所 示 用 机 村 


1) DropDownList 控件 的 关键 属性 
DropDownList 控件 的 关键 属性 及 其 含义 如 表 3-4 所 示 。 
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表 3-4 DropDownList 控件 的 关键 属性 及 其 含义 


属性 ,方法 或 事件 取 值 取 值 的 含义 

DataSource 属性 数据 源 名 称 ”设置 为 选项 提供 字段 的 数据 源 的 名 称 

DataTextField 属性 字段 名 称 把 指定 的 字段 绑 定 为 对 象 的 选项 

DataValueField 属性 字段 名 称 把 指定 的 字段 作为 对 象 的 返回 值 ,例如 ,显示 职工 姓 
名 ,但 选中 后 以 职工 号 作为 选择 值 

item 属性 说 明 对 象 的 选项 集 , 可 以 使 用 Items. Add( 选 项 信息 ) 
添加 选项 ,也 可 用 Items. Clear() 方 法 清除 全 部 选项 

SelectedItem 属性 当前 选 定 的 项 

SelectedValue 属性 当前 选 定 项 的 返回 值 一 一 经 常 使 用 


SelectedIndexChanged 事件 
DataBind( ) 方 法 


2) 创建 DropDownList 控件 


当选 定 某 一 选项 时 ,此 事件 被 触发 
绑 定 数据 源 


当 把 下 拉 式 列表 框 从 工具 箱 中 拖 动 到 窗 体 后 ,就 创建 了 一 个 下 拉 式 列表 框 对 象 。 此 时 


有 三 种 方法 设置 其 选项 。 
(1) 直接 编辑 下 拉 式 列表 框 的 选项 


名 单 击 此 对 象 右上 角 的 智能 小 按钮 ,从 中 选择 [编辑 项 功能 , 即 可 打开 一 个 添加 项 目 


的 对 话 框 ,如 图 3-3 所 示 。 


Listtem 集合 当当 二 
或 员 (M): Uistitem 属性 DP): 
4 剧 绅 旦 

日 有 硕 

Enabled True 

Selected False 

Text 

Value 
Er 

Le _ jLm | 


3-3 DropDownList 控件 的 选项 设置 


@ 单 击 此 对 象 左 下 角 的 [添加 按钮 , 则 在 [成员] 框 中 添加 了 一 个 Listltem( 选 项 ), 此 
时 可 以 在 右 侧 的 [ListItem 属性 ] 框 中 修改 此 选项 的 Text( 显 示 值 ) 和 Value( 返 回 值 ) 值 ,二 


者 默认 为 相同 。 


@ 最 后 单 击 【确定 了 按钮 ,确认 对 选项 的 设置 。 


(2) 利用 C# 代 码 为 下 拉 式 列表 框 添加 


选项 


假设 对 象 名 称 (ID) 为 ddl, 那 么 在 C# 代码 下 通常 采用 的 语句 如 下 : 
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ddl. Items. Clear( ); 


ddl. Items. hdd(new ListItem( 作 为 选项 的 字符 串 变 量 ) ); 


// 清 空 原 有 的 选项 
// 新 增 选 项 


ddl. Items. Romove( 项 对 象 ) 或 者 ddl. Items. RomoveAt( 项 序号 ) // 删 除 指定 的 选项 


(3) 利用 数据 库 的 字段 为 下 拉 式 列表 框 设 置 


5 二 源 配 于 向 忆 DLLE 
假定 某 数据 库 已 经 在 当前 项 目 中 被 设 定 为 数据 | = 
源 sjk, 其 中 包含 数据 表 职 工 表 (zgb) ,其 中 有 字段 | seaae 
姓名 (xm) ,职工 号 (xh) 等 信息 。 和 - 
当下 拉 式 列表 杠 对 象 创建 完毕 , 单 击 此 对 象 右 | 面 
上 角 的 智能 按钮 ,从 其 * 智 能 菜单 "中 选择 [选择 数据 | opoomun masvazac 


源 ] 功 能 ,启动 配置 界面 ,如 图 3-4 所 示 。 

在 此 界面 中 选择 数据 源 ,显示 字段 和 值 字段 ,确定 
即 可 。 事实 上 ,也 可 以 直接 在 其 [属性] 面板 中 设置 属 
性 DataSource、DataTextField 和 DataValueField 的 值 
为 : sik、xm 和 xh。 自 动 生成 的 代码 如 图 3-5 所 示 。 

5. ListBox 控件 


™™ Bsn ess 


3-4 以 数据 源 为 DropDownList 


ListBox 是 列表 框 , 它 是 一 个 显示 为 多 行 的 矩形 控件 设置 选项 
区 域 , 其 中 提供 多 个 选项 供用 户 选择 。 它 的 选项 设 
置 方法 与 DropDownList 基本 相同 。 
38 asp:JropJownList ID="DroplownListl™ runat="server™ MutoPosthack="True™ 
39 DataSourceIl="sjk" DataTextField="xm" DataValueField="xh"> 
如 asp: DropDownList> 
41 asp:SqllataSource ID="sjk" runat="server" 
2 ComectionStrine=" %$ ConnectionStrings:NaConmectionString %>" 
43 SelectCommand="SELECT DISTINCT [xh], [xm] FROM [xsb]"><fasp:SglDataSouree> 


3-5 ”以 数据 源 为 DropDownList 控件 设置 选项 的 aspx 代码 


ListBox 与 DropDownList 的 区 别 表现 为 两 点 : 其 一 ,ListBox 占用 一 个 矩形 空间 ,为 用 
户 提供 多 个 选项 ; 其 二 ,如 果 其 属性 SelectionMode 设置 为 Multiple,ListBox 对 象 允许 用 户 
同时 选中 多 个 选项 。 


ListBox 的 效果 如 图 3-6 所 示 。 


遍 注意 : 在 允许 同时 选中 多 项 的 情况 下 ,其 SelectedValue 值 只 


3-6 ”ListBox 的 显示 


i 能 输出 第 一 个 选项 的 值 ,要 想 输 出 全 部 选项 ,可 以 使 用 “对 人 象 名 . 
Items[ 选 项 序号 ]. Selected” 属 性 逐 项 进行 判定 。 例 如 ,假设 有 列 


效果 图 表 框 对 象 lb, 允 许多 项 同时 选中 , 则 判定 选择 结果 的 C# 片 段 为 : 


for(int i= 0;i< 1lb.Items.Count;i++) 


if(1b. Items[ i]. Selected) Response. Write(1b. Items[i]. Value. ToString()); 


6. RadioButton 与 RadioButtonList 控件 


RadioButton 控件 也 叫 单 选 按钮 控件 ,主要 用 于 表示 多 个 选项 互 斥 的 选择 关系 ,其 每 个 
选项 框 都 要 使 用 一 个 独立 的 RadioButton 对 象 。 而 RadioButtonList 控件 是 把 多 个 互 斥 选 


项 组 织 在 一 个 RadioButtonList 对 象 之 中 。 
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在 实际 的 应 用 中 ,为 了 表示 多 个 相关 的 单 选 按钮 具有 互 斥 关系 (如 性 别 中 的 “ 男 ? 和 "* 女 ” 
就 是 互 斥 的 ) ,需要 把 多 个 单 选 按钮 控件 组 织 在 一 个 组 (Group) 中 。 

为 了 表示 教师 的 职称 选项 ,可 以 使 用 的 两 种 方式 如 下 。 

1) 利用 RadioButton 制作 互 斥 选项 

向 当前 窗 体 中 连续 添加 5 个 RadioButton 控件 ,并 且 利用 【属性 】 面 板 使 它们 使 用 统一 
的 组 名 ”jszc”, 把 这 5 个 控件 编 为 一 组 ,从 而 保证 选项 之 间 的 互 斥 关系 ,最 后 分 别 设置 这 5 个 
控件 的 Text 属性 值 。 最 终 得 到 的 aspx 代码 如 图 3-7 所 示 ,页 面 显 示 效 果 如 图 3-8 所 示 。 


教师 职称 : 

<asp:RadioButton ID = rbl Runat = "Server" Groupname = "jszc" Text = "教授 "/><br> 
<asp:RadioButton ID = rb2 Runat = "Server" Groupname = "jszc" Text = "副教授 "/><br> 
<asp:RadioButton ID = rb3 Runat = "Server" Groupname = "jszc" Text = "讲师 "/><br> 
<asp:RadioButton ID = rb4 Runat = "Server" Groupname = "jszc" Text = "助教 "/>< br> 
<asp:RadioButton ID = rb5 Runat = "Server" Groupname = "jszc" Text = " 教 辅 "/>< br> 


图 3-7 设置 RadioButton 的 aspx 代码 


对 于 图 3-7 中 的 代码 ,可 以 利用 以 下 C# 语句 获 gg sp 


户 的 选择 信息 : 
3-8 ”RadioButton 的 显示 效果 图 
if(rbl. Checked) str = "教授 "; 
if(rb2. Checked) str = "副教授 "; 
if(rb3. Checked) str = "讲师 "; 
if(rb4. Checked) str = "助教 "; 
if(rb5.Checked) str = " 教 辅 "; 


2) 利用 RadioButtonList 制作 互 斥 选项 

向 当前 窗 体 中 添加 1 个 RadioButtonList 控件 ,并 且 利 用 其 右上 角 的 “智能 按钮 "打开 
【编辑 项 功能 ,在 [ListItem 集合 编辑 器 ] 对 话 框 中 为 它 增 加 5 个 选项 。 最 终 得 到 的 aspx 代 
码 如 图 3-9 所 示 ,页 面 显示 效果 如 图 3-10 所 示 。 


取 


教师 职称 : 

<asp:RadioButtonList ID = "rbl" runat = "server"> 
<asp:ListItem > 教授 </asp:ListItem> 
<asp:ListItem> 副 教授 </asp:ListItem> 
<asp:ListItem > 讲师 </asp:ListItem> 
<asp:ListItem> 助 教 </asp:ListItem> 
<asp:ListItem > 教 辅 </asp:ListItem> 
</asp:RadioButtonList> 


图 3-9 设置 RadioButtonList 控件 的 aspx 代码 


对 于 图 3-9 中 的 代码 ,可 以 利用 以 下 语句 获取 输入 数据 : 
副教授 
ee str = rbl. Selected Valve; 
9 助教 
注意 : 对 于 创建 在 窗 体 中 的 RadioButtonList 对 象 , 可 以 
3-10 RadioButtonList 控 单 击 其 右上 角 的 三 角 , 打开 [ListItem 集合 编辑 器 】〗 对 话 框 ,为 
件 的 运行 效果 图 RadioButtonList 对 象 添加 选项 ,并 设置 选项 的 Text 和 Value 
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属性 。 
此 【ListItem 集合 编辑 器 ] 对 话 框 与 DropDownList 控件 的 [ListItem 集合 编辑 器 ] 对 话 
框 完全 相同 。 

7. CheckBox 与 CheckBoxList 控件 

CheckBox 控件 也 称 复 选 框 控件 ,主要 用 于 表示 多 个 选项 可 以 同时 选中 的 选择 关系 ,其 
每 个 选项 框 都 使 用 一 个 独立 的 CheckBox 对 象 。 与 此 相应 , VS2008 系统 还 提供 了 
CheckBoxList 复 选 框 组 。 例 如 ,为 了 表示 "我 的 爱好 ”选项 ,可 以 使 用 以 下 两 种 方式 。 

1) 利用 CheckBox 制作 选项 

利用 [工具 箱 ] 向 当前 窗 体 中 连续 添加 5 个 CheckBox 控件 ,分 别 设置 这 5 个 控件 的 ID 
属性 和 Text 属性 值 ,最 终 得 到 的 aspx 代码 如 图 3-11 所 示 , 页 面 显示 效果 如 图 3-12 
所 示 。 


您 的 爱好 是 : <br /> 

<asp:CheckBox ID = "cbSing" runat = "server" Text = "唱歌 " /> 
<asp:CheckBox ID = "chDance" runat = "server" Text = "跳舞 " /> 
<asp:CheckBox ID = "cbSwim" runat = "server" Text = "游泳 "” /> 
<asp:CheckBox ID = "cbRun" runat = "server" Text = "跑步 " /> 
<asp:CheckBox ID = "cbSkip" runat = "server" Text = "跳高 " /> 
<br /> 


图 3-11 设置 CheckBox 控件 的 aspx 代码 


对 于 图 3-11 中 的 代码 ,可 以 利用 以 下 C# 语 句 获取 用 户 rg 


的 选择 信 自 同 唱歌 四 跳舞 同 游泳 同 跑步 月 跳高 
二 图 3-12 CheckBox 控件 的 
9 运行 效果 图 


if(cbSing. Checked) str += "唱歌 "; 
证 (cbDance. Checked) str += "跳舞 "; 
证 (cbSwim. Checked) str += "游泳 "; 
证 (cbRun. Checked) str += "跑步 "; 
证 (cbSkip. Checked) str += "跳高 "; 
2) 利用 CheckBoxList 制作 选项 
向 当前 窗 体 中 添加 1 个 CheckBoxList 控件 ,并 且 利用 其 右上 角 的 “智能 按钮 "打开 【 编 
辑 项 ] 功 能 ,在 [ListItem 集合 编辑 器 】 对 话 框 中 为 它 增加 5 个 选项 ,最 终 得 到 的 aspx 代码 如 
图 3-13 所 示 ,最终 的 运行 效果 如 图 3-14 所 示 。 


您 的 爱好 是 : <br /> 

<asp:CheckBoxList ID = "cb1l”runat = " server"> 
<asp:ListItem > 唱歌 </asp:ListItem> 
<asp:ListItem > 跳舞 </asp:ListIten> 
<asp:ListItem > 游泳 </asp:ListItem> 
<asp:ListItem > 跑步 </asp:ListItem> 
<asp:ListItem > 跳高 </asp:ListItem> 
</asp:CheckBoxList> 


图 3-13 设置 CheckBoxList 控件 的 aspx 代码 
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对 于 图 3-14 中 的 代码 ,可 以 利用 以 下 语句 获取 输入 
数据 : 


String str = ""; 

for(int i = 0; i <cbl. Items.Count; i++) 

if(cbl. Items[i]. Selected) str = str + cbl. Items[i]. 
Value. ToString(); 


图 3-14 CheckBoxList 控件 的 
运行 效果 图 

注意 : CheckBoxList、RadioButtonList、DropDownList 
和 ListBox 直接 添加 选项 的 方法 完全 相同 。CheckBoxList 获取 选中 值 的 方法 与 ListBox 的 
多 选 情况 相同 。 

8. Image 控件 与 ImageMap 控件 

Image 控件 是 一 个 显示 图 像 的 控件 ,用 于 在 Web 窗 体 上 显示 图 像 ,被 显示 的 图 像 文件 
的 名 称 信息 可 由 其 ImageUrl 属性 通过 【属性 ] 面 板 设置 ,也 可 以 在 编程 时 指定 。 注 意 ， 
Image 控件 不 响应 Click 事件 。 

ImageMap 控件 是 一 个 支持 在 图 像 上 建立 热点 链接 的 控件 ,被 它 显示 的 图 像 文件 也 由 
其 ImageUrl 属性 设 定 。 另 外 ,还 可 以 利用 其 属性 HotSpot 设置 热 区 ,为 热 区 创建 超 链接 。 
在 实际 的 开发 中 ,常常 使 用 ImageMap 控件 制作 导航 条 、 地 图 等 。 

ImageMap 控件 的 关键 属性 如 表 3-5 所 示 。 


表 3-5 ”ImageMap 控件 的 关键 属性 


属性 方法 或 事件 | 取 值 取 值 的 含义 


在 终端 用 户 单 击 热 区 之 后 ,应 把 该 单 击 事件 回 送 给 服务 器 ,并 在 服 
务 器 上 处 理 该 单 击 事件 

Navigate | 导航 到 一 个 完全 不 同 的 URL 

InActive “| 不 激发 任何 操作 

JmageUrl 指定 要 显示 的 图 像 文 件 

NavigateUrl 设置 单 击 热 区 后 要 到 达 的 网 址 ,应 与 每 个 热 区 对 应 


PostBack 
HotSpotMode 


注意 ; 如 果 ImageMap 的 HotSpotMode 属性 值 设置 为 PostBack', 而 且 创建 了 几 个 热 
区 ,后 台 的 C# 程 序 就 必须 先 确定 选择 了 哪个 热 区 ,然后 才能 执行 相应 的 工作 。 要 确定 这 一 
点 ,可 以 使 用 PostBackValue 属性 给 每 个 热 区 指定 一 个 回 送 值 ,以 便 C# 程 序 判 定 。 

9. HyperLink 控件 

HyperLink 控件 是 Web 窗 体 技术 下 的 超 链接 控件 ,负责 为 文字 和 图 片 创建 超 链接 ,其 
功能 与 HTML 语言 中 的 过 a href> 基 本 相同 ,但 HyperLink 可 以 与 数据 源 绑 定 ,具有 更 丰 
富 的 功能 。 

HyperLink 对 象 通过 NavigateUrl 属性 设置 目标 网 址 ,以 [属性 了 面板 的 Text 属性 设置 
文字 性 信息 ,以 ImageUrl 属性 设置 图 像 文 件 的 信息 。 例 如 : 

<asp:HyperLink ID = "HyperLink1" runat = "server" ImageUrl = "~/hills. JPG" 

NavigateUrl = "http://www. bnu. edu. cn/"> 北 京师 范 大 学 </asp:HyperLink> 

10. Panel 控件 

Panel 控件 也 称 面板 ,是 一 个 容器 控件 ,可 以 看 成 放 在 Web 窗 体 中 的 一 块 平板 。 在 这 个 
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平板 上 可 放置 多 个 控件 。 
Panel 面板 可 以 通过 Visible 属性 设置 其 可 视 性 ,如 果 面 板 的 Visible 属性 被 设置 为 
false, 则 面板 成 为 不 可 见 状态 ,其 中 的 所 有 对 象 都 自动 变 成 不 可 用 状态 。 


3.2.3 实用 案例 


1. 标签 .文本 框 与 RadioButton .CheckBox 的 综合 程序 
设计 一 个 综合 性 的 程序 ,测试 各 种 控件 的 应 用 ,其 最 终 运行 效果 如 图 3-15 所 示 。 


gy] A 
rs | 
[3 -a | 
Sqlpatasourcs -让 
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| 师 目 ， 

| 对 区 

| 融 手 和 
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开关 贡 广 攻 三 昌 步 厂 路 让 _ | 的 许 是 ， 
aa 

是， 

| 中 

jr 中 

| 区 

| 

| 
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图 3-15 测试 各 种 控件 综合 应 用 的 程序 的 界面 


(1) 主要 操作 方法 

在 【解决 方案 管理 器 了 面板 中 ,新 增 Web 窗 体 Control ,并 按照 图 3-15 添加 各 种 控件 ,并 设置 
控件 的 属性 ,得 到 的 aspx 代码 如 图 3-16 所 示 。 与 图 3-15 对 应 的 操作 代码 (C# ) 如 图 3-17 所 示 。 

(2) 对 应 的 操作 代码 

2. 关于 院 系 与 专业 的 级 联 程序 

已 知 物理 系 有 力学 .热学 ,原子 物理 .光学 .电子 学 专业 ,化 学 系 有 化 学 原理 ,有 机 化 学 、 
无 机 化 学 .生物 化 学 专业 ,信息 系 有 信息 系统 、 网 络 组 织 、. 图 书 情报 、 信 息 管理 专业 。 请 设计 
一 个 DropDownList 和 一 个 ListBox, 使 两 者 之 间 实 现 联动 。 

(1) 设计 思路 

首先 定义 一 维 数组 ,为 字符 串 型 ,用 于 存储 系 名 称 。 然 后 定义 一 个 锯齿 型 二 维 数组 ,在 
每 行 对 应 存储 一 个 院 系 中 的 各 个 专业 名 称 。 接 着 定义 一 个 DropDownList 和 一 个 ListBox 
对 象 ,把 院 系数 组 内 容 赋予 DropDownList 的 选项 中 ,然后 在 C# 中 针对 院 系 对 象 的 选中 事 
件 (SelectedIndexChanged) 设 置 程序 ,以 程序 修改 ListBox 的 选项 内 容 。 

(2) 主要 操作 方法 

在 【解决 方案 管理 器 】 面 板 中 ,新 增 Web 窗 体 Control, 并 按照 图 3-18 添加 各 种 控件 ,并 
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1 Wa Fage Language="C#" AntoEyentWireup= true” CodeBehind="Control. aspx. cs" Inherits="NyTest3. Default" 
2 <IDOCTIPE htnl PUBLIC "~//W3C//DTD XHTML 1.0 Transitional//EN" 

"http: / /wew, w3, org/TR/xhtml1 /DTD/xhtnll-transitional. dtd"> 

html xmlns="http: /www. w3. org/1999/xhtnl” > 
5 Chead runat="server"> 
人 《title) 无 标题 页 人 title> 
head> 
Bh Chody>form id-"fornl" runat="server">Cdiv> 
9 您 要 选择 的 职工 号 : 《br /> 
[Ue 《asp:JropJownList ID="db]" runat="server" AutoPostBack="True" 
11 DataSourceID="sjk" DataTextPield="xm" DataValueField="xh" Height="28px" 
12 Wiath="238px"> 
13 fasp: DrophownList> 
L140 asp:SqlDataSource ID="sjk" runat="server" 
15 ConnectionString="<%$ ConnectionStrings:llaConnectionString WS" 
16 SelectCommand="SELECT DISTINCT [xh], [xm] FROM [xsb]">K/asp:SalDataSource》 
17 《asp:Button ID="dblbtn" runat="server”Text=" 下 拉 式 列表 框 出 式 ”onelick="dblbtn_Click" /> 
18 您 的 选择 是 : 《asp:Label ID="dbles" runat="server”>X/asp:Label> 
19 hr />Gr {> 
0 您 要 选择 的 项 目 : 《br /> 
1 《asp:ListBox ID="]b" runa ei ght="92px" 
2 Selectionlode="Multiple" Width="210px"> 
3 istItem) 教 授 《/ asp:ListIten> 
4 istIten 瘟 懒 援 dfasp:ListIten> 
5 istTtem)# 师 Yasp:ListIten> 
6 <asp:ListItem) 助教 Casp:ListItem> 
T 《asp:ListIten ) 孝 畏 人 /asp:ListIten> 
8 asp:ListBox> 
9 引 《asp:Button ID="1bbtn" runat="server" Text=" 列 表 框 出 式 ” onclick="lbbtn_Click" /> 
0 您 的 选择 是 : 《asp:Label ID="lbes" runat="server">GWasp:Label> 
1 Cbr />Cbr /> 
2 您 的 职称 是 ; 
3 
4 
5 
8 
9 
0 
1 


《asp:RadioButton ID="rbl" runat: 
《asp:RadioButton ID="rb2" runat: 
Casp: RadioButton ID="rb3" runat: 
dioButton ID="rb4" runat: 
a: adioButton ID="rb5" runm 教 辅 " GroupNane="xb" /> <br /> 
《asp: Button ID="rbbtn" runat= 单 选 核 钮 独 计 "onclick="rbbtn_Click" /> 
您 的 选择 是 : 《asp:Label ID="rbtes" runat="server">X</asp:Label》 
br /> br 办 
您 的 职称 是 : 《asp:Radi oButtonList ID="rbl” runat="server"》 

《asp:ListIten) 教 授 <7asp:ListIten》 
stItem) 宙 | 教 授 C/asp;ListItem> 
istTtem2i 井 师 人 /asp:ListIten 站 
stItem》 助 教 C/ asp:ListItem> 
kej 《asp:ListItem) 者 \ 辅 Casp:ListIten> 
hr 人 asp:RadioputtonList> 
| 《asp:Button II="rblbtn” runat="server" onclick="rblbtn_Click" Text=" 单 选 按钮 组 测试 " /> 
上 您 的 选择 是 : 《asp:Label ID="rbles" runat="server"》《/asp:Label》 
0 <br /> br 1> br /> 


助教 ”GroupNane= xb” /> 


《as] 


《asp:CheckBox ID="cbSing" runat="server" Text=" 唱 歌 " /> 


Kasp: CheckBox 

让 Casp: Button ID="fxkbtn" runat="server" Text= i onclick="fxkbtn Click" /> 
人 法 近 星 : pad Label ID="cbes" runat="server">K/asp:Label》 

br {> Cbr /> 

您 的 爱好 是 : 《br /> 

0 asp:CheckBoxList ID="cb]" runat="server"> 

:ListItem 竟 歌 Casp:ListIten> 

stItem) 幅 舞 C/asp:ListIten> 

istIten》 注 泳 CYasp; ListItem> 

istItem) 侈 步 Casp:ListIten> 

stItem) 吕 高 《fasp:ListItem> 


fasp: CheckBoxList> <hr 六 
asp: Button ID="cblbtn" runat="server” onclick=" cblbtn_Click" Text=" 复 选 框 组 出 试 " 7> 
您 的 选择 是 : 《asp:Label ID="cbles" runat="server">Gfasp:Label> 

Ydiv> 

§ Eorm> body> htnl> 


图 3-16 测试 控件 的 综合 应 用 的 aspx 代码 
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i149 nanespace JlyTest3 
15:| { 


public partial class Default : System. Web.UI.Page 
[ 


protected void Page Load(cbject sender, Eventhrgs e) 


} 
protected void dblbtn_Click (object sender，Everthres e) // 响 应 下 拉 式 列表 框 
. 


dblcs. Text = dbl. SelectedYalue. ToString() ; 
} 


protected void lbbtn_Click (object sender，EventArgs e) // 响 应 列表 框 单 击 事件 
, 


String str=""; 
for (int i = 0; i < lb.Items.Count; i++ 
if (lb,Items[i].Selected) str=str+lb. Itens[i].Value. ToString () ; 
) lbcs, Text = str; 


Breetol void rbbtn_Click (object sender，Eventhrgs e) // 响 应 单 选 按钮 事件 
String str = ""; 

f(rbl.Checked) str=" 教 授 "; if (rb2.Checked) st 

if (rb3. Checked) str=" 讲 师 " ; if (rbd. Checked) str= 

f(rb5.Checked) str=" 款 辅 " ; 

Tbtcs, Text=str; 


protected void rblbtn_Click (object sender，Eventhrgs e) // 响 应 单 选 按钮 表 组 事件 


rblcs, Text = rbl, SelectedYalue, ToString() ; 
} 


protected void fxkbtn_Click (object sender，Eventhres e) 77 响应 复 选 框 事件 
String str = ""; 

证 (cbSing.Checked) str += " 
if (cbSwim Checked) str += 
if (cbSkip.Checked) str += 
cbcs. Text = str; 


证 (cbDance.Checked) str += "跳舞 " ; 
f (cbRun.Checked) str += "跑步 "; 


protected void cblbtn_Click (object sender，Evertargs e) // 响 应 复 选 框 表 组 事件 
tring tr sa""; 
for (int i = 0; i < cbl.Itens.Count ; i++) 

if (cbl.Items[i].Selected) str = str + cbl. Itenms[i].Value.ToString () ; 
cbles. Text = str; 


图 3-17 测试 控件 的 综合 应 用 的 C# 代 码 


设置 控件 的 属性 。 

设置 DropDownList 的 ID 为 dbIDw,ListBox 的 ID 为 本 生生 
lbZhy,Button 的 ID 为 btnSee,Label 的 ID 为 result。 为 保 a 愧 | 
证 院 系 名 称 的 变化 能 够 及 时 引发 专业 名 称 变化 ,应 该 把 院 | 
系 DropDownList 的 AutoPostBack 属性 修改 为 true。 然 
后 切换 到 aspx. cs 编码 方式 下 ,编写 如 图 3-19 所 示 的 代码 。 图 3-18 控件 级 联 程序 的 界面 图 


二 | 。 您 和 择 的 院 系 和 专业 是 ，frea 
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1 nonespace NyTect3 
15|{ 


16 由 publie partial class Nebfornl : Systen Web. UT. Page 

17 { 

18: public string【]xbmc={" 物 理 系 ", "化 学 系 ", "信息 系 "}; 

19 public string [][]zyme = new string[3][]: 

20 

Bt protected void Page_Load(object sender, Eventhres e) 

下 if (IIsPosthack) 

24 { 

25 dblDw. Ttems. Clear (); 术 清 空 院 系 名 称 下 拉 列 表 框 的 选项 
26 for (int i = 0; i《 xbme.Length; it+) 彤 利 用 数组 为 院 系 下 拉 列 表 框 距 予 选项 
27 dblDw. Ttens. Add (xbme[i]. Trim 0); 


28 } 
29 } 


protected void dblDw_SelectedIndexChanged(object sender, Eventhres 
' /响应 院 系 名 称 六 tt 


zyme[0] = new string[5] { "力学 "，" 执 学 "，" 原 子 : 
zyme[1] = new string[4] { "化 学 原理 "， ee 


i Ei 
zymc[2] = new string[4] { "信息 系统 "， 人 情报 "， 管理 "”}; 
36 lbzhy Ttens. Clear 0 ; 从 
37 int i = dbllw. SelectedIndex; / 绪 取 院 条 名 称 框 的 选中 项 的 序号 
38 for lint j = 0; j < zyme[i].Length; jt+) 和 六 息 装 肥 | 专 业 名 称 列表 框 中 
| lbZhy. Items. Add (zyme [i][j]. Trim O):; 
40 } 
CV 
息 训 protected void btnSee_Click(object sender，Eventhres e) /fl 响应 按 蔚 事件 ， 显示 选择 结果 
43: { 
44 String xbm, zym: 
45 xbm = dblDw. Selectedyalue. Trim(); 
46: zym = lbZhy. Selectedyalue. Trim(); 
47 result. Text = xbm + "学 院 " + zym + "专业 "; 
48 
49 } 
Soit} 


图 3-19 控件 级 联 程序 的 C# 代码 
6.3 Web 服务 器 的 验证 控件 


3.3.1 数据 输入 验证 的 必要 性 与 方法 


1. 数据 输入 验证 的 必要 性 

在 交互 式 网 站 开发 中 ,经 常 需要 通过 表单 获取 用 户 输入 的 信息 ,例如 注册 信息 、 网 上 调 
查 \ 网 上 购物 车 等 。 然 而 ,由 于 系统 面临 的 用 户 具 有 不 同 的 层次 ,计算 机 操作 的 能 力也 有 很 
大 差异 ,用 户 很 可 能 通过 表单 输入 了 一 些 垃圾 信息 、 不 规范 信息 ,导致 系统 的 不 稳定 。 为 解 
决 这 一 问题 ,对 用 户 输入 的 数据 开展 验证 是 非常 必要 的 。 

验证 并 不 能 保证 数据 的 完全 正确 ,但 可 以 从 一 定 程度 上 保证 数据 的 完整 性 和 合理 性 。 
例如 ,可 以 约束 电话 号 码 中 没有 字母 ,约束 身份 证 的 格式 符合 规范 ,约束 学 号 字段 必须 输入 
10 位 数码 的 学 号 ,等 等 。 事实 上 ,验证 就 是 由 开发 人 员 提 出 一 种 规则 ,通过 这 种 规则 限制 输 
入 数据 的 格式 。 

2. 数据 输入 验证 的 方法 

对 于 用 户 输入 的 数据 ,有 两 种 验证 方式 : 其 一 是 客户 端 验 证 ,其 二 是 服务 器 端 验证 。 所 
谓 客户 端 验证 ,就 是 在 网 页 中 设计 一 段 JavaScript 代码 ,在 用 户 输入 数据 后 ,这 段 代码 由 用 
户 的 浏览 器 执行 ,进而 实施 数据 验证 ,只 有 通过 验证 的 数据 才 会 被 传送 到 服务 器 上 。 所 谓 服 
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务 器 验证 ,就 是 系统 把 用 户 通 过 表单 输入 的 数据 回 传 到 服务 器 上 ,由 服务 器 上 的 程序 进行 数 
据 的 合法 性 验证 。 

对 比 上 述 两 种 验证 方法 ,客户 端 验 证 具有 本 地 验证 ,不 浪费 网 络 资源 ,减轻 服务 器 负担 
的 优势 ,但 其 验证 代码 暴露 在 客户 端 , 可 被 任何 用 户 阅读 ,安全 性 不 强 。 服 务 器 端 验证 则 
相反 。 

ASP.NET 3.5 通过 服务 器 控件 的 形式 提供 了 窗 体验 证 ,具有 一 定 的 智能 性 。 在 ASP . 
NET 生成 页 面 时 会 自动 根据 客户 机 是 否 支持 JavaScript 来 决定 采取 哪 种 验证 方式 ,并 生成 
相应 的 验证 脚本 。 


3.3.2 窗 体验 证 技术 


ASP.NET 为 窗 体 验证 主要 提供 了 以 下 6 个 控件 : 不 允许 空白 控件 (RequiredFieldVal- 
idator) 要求 相 同 控件 (CompareValidator) ,范围 约束 控件 (RangeValidator) .正则 表达 式 控 
件 (RegularExpressionValidator) 用户 定义 验证 控件 (CustomValidator) 验证 汇总 控件 
(ValidationSummary) 。 

1. 窗 体验 证 控件 的 公共 属性 

在 6 个 窗 体验 证 控件 中 ,前 5 个 控件 是 负责 对 表单 控件 进行 验证 的 ,最 后 一 个 控件 是 负 
责 汇总 验证 信息 的 。 因 此 前 5 个 验证 控件 具有 一 些 很 相似 的 共同 属性 ,如 表 3-6 所 示 。 


表 3-6 窗 体验 证 控件 的 公共 属性 表 


属性 \ 方 法 或 事件 取 值 取 值 的 含义 

ControlToVadidate 表单 控件 名 指定 被 验证 的 控件 名 (说 明 哪 个 控件 被 检验 ) 

Static 验证 控件 始终 占用 窗 体 控 件 
Display Dynamic 只 有 被 检验 控件 的 信息 错误 时 才 占用 空间 

None 错误 信息 被 收集 到 ValidationSummary 对 象 中 
EnableClientScript true/false 用 于 设置 是 否 启用 客户 端 JavaScript 验证 ,默认 为 true 
ErrorMessage 字符 串 出 错 提示 信息 ,可 以 用 ValidationSummary 对 象 收集 
SetFocusOnError true/false 当 被 验证 数据 出 错时 ,是 否 将 焦点 定位 到 出 错 的 控件 上 
Text 设置 验证 控件 显示 的 信息 (如 对 必 输 入 对 象 , 显 示 * ) 


2. RequredFieldValidator 控件 

被 RequiredFieldValidator 控件 检验 的 对 象 不 允许 输入 空白 值 。 

通常 ,可 以 把 RequiredFieldValidator 控件 从 [工具 箱 ] 中 拖 出 来 , 放 到 被 检验 的 对 象 后 
面 。 接 着 ,利用 [属性 ] 面 板 设 置 RequiredFieldValidator 的 属性 ControlToVadidate 为 被 检 
验 对 象 的 名 称 ,表示 此 对 象 被 RequiredFieldValidator 验证 。 然 后 ,设置 其 Text 属性 值 为 
“x ”, 设 置 其 ErrorMessage 的 出 错 提 示 信 息 。 

另外 , RequiredFieldValidator 控件 还 有 一 个 常用 的 属性 InitialValue。 如 果 设 置 了 
InitialValue 的 属性 值 , 当 被 检验 对 象 的 输入 数据 与 InitialValue 属性 值 相同 时 ,也 会 被 认为 
是 出 错 状态 。 

如 果 ErrorMessage 中 使 用 JavaScript 的 alert 语句 ,能 够 获得 警示 框 式 的 提示 信息 , 达 
到 比较 好 的 实现 效果 。 
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3. CompareValidator 控件 

CompareValidator 控件 用 于 验证 两 个 输入 对 象 的 值 是 否 一 致 。 在 实际 开发 中 ,常常 用 
于 检测 “密码 ”与 “确认 密码 ?是 否 相同 。 

CompareValidator 控件 用 属性 ControlToVadidate 和 ControlTbCompare 绑 定 两 个 需要 验 
证 的 对 象 。 其 他 设置 信息 与 RequiredFieldValidator 控件 基本 相同 。 另 外 ,本 控件 还 可 以 判定 
被 验证 对 象 的 输入 值 是 否 与 指定 的 数据 相同 (Type 属性 说 明 数 据 类 型 ,ValueToCompare 属 
性 存储 被 比较 的 数值 ) 。 

对 CompareValidator 控件 的 设置 也 通过 【属性 了 面板 完成 。 

4. RangeValidator 控件 

RangeValidator 是 范围 约束 控件 ,用 于 约束 被 验证 对 象 的 输入 数据 是 否 在 指定 范围 之 
内 。 例 如 ,限制 考试 成 绩 ( 文 本 框 ) 的 数据 必须 在 0 一 100 之 间 , 限 制 大 学 生年 龄 在 14 一 40 岁 
之 间 , 等 等 。 除 了 ControlToVadidate 属性 说 明 被 验证 对 象 外 ,本 控件 还 有 MaximumValue 
和 MinimumValue 属性 限制 数据 的 最 大 值 和 最 小 值 ,以 Type 属性 说 明 数 据 的 类 型 。 

5. RegularExpressionValidator 控件 

RegularExpressionValidator 是 正则 表达 式 控 件 , 主 要 用 于 限制 输入 对 象 的 值 必须 满足 某 
种 特定 的 格式 。 例 如 身份 证 号 .具有 特定 格式 的 职工 号 .电话 号 码 等 。 

除了 ControlToVadidate 和 ErrorMessage 属性 外 ,本 控件 还 有 一 个 重要 属性 
ValidationExpression 属性 ,本 属性 要 求 输入 一 个 字符 串 形式 的 正则 表达 式 。 

对 于 正则 表达 式 的 书写 ,还 是 比较 烦琐 的 。 好 在 VS2008 提供 了 多 种 可 以 直接 选用 的 
正则 表达 式 ,减轻 了 开发 者 的 负担 。 

6. CustomValidator 控件 

CustomValidator 是 用 户 自 定义 验证 控件 。 其 含义 是 由 开发 者 设计 程序 并 利用 程序 进 
行 输入 验证 ,本 控件 支持 客户 端 验证 和 服务 器 端 验证 两 种 方式 。 如 果 同 时 提供 两 种 验证 方 
式 , 则 客户 端 验证 方式 优先 。 

客户 端 验证 要 求 用 JavaScript 程序 编写 一 个 函数 (function) ,由 此 function 在 客户 端 实 
施 输 入 验证 ; 而 服务 器 端 验证 也 要 求 开发 者 用 C# 开 发 一 个 验证 函数 ,由 验证 函数 实施 验 
证 。 在 这 两 个 函数 中 ,以 source 和 args 作为 函数 的 参数 ,其 中 args. Value 表示 验证 对 象 的 
输入 值 ,验证 结果 存储 到 args. IsValid 中 ,验证 成 功 赋值 true, 和 否则 赋值 false。 

除了 ControlToVadidate 和 ErrorMessage 属性 外 ,本 控件 还 有 两 个 专门 的 属性 : 
onServerValidate 属性 指明 服务 器 端 验 证 的 C# 的 函数 名 ,而 ClientValidationFunction 属 
性 指明 客户 端 验证 的 JavaScript 函数 名 。 

7. ValidationSummary 控件 

控件 ValidationSummary 的 作用 是 综合 输出 一 个 窗 体 中 的 全 部 ErrorMessage 信息 。 
本 控件 不 需要 特定 的 设置 ,把 此 控件 拖 动 到 窗 体 的 适当 位 置 即 可 。 


3.3.3 对 学 生 注 册 信 息 的 综合 验证 


1. 基本 要 求 
对 于 如 图 3-20 所 示 的 输入 界面 进行 输入 验证 。 要 求 : 限制 学 号 只 能 输入 8 位 数码 ,姓名 必 
须 输入 ,年 龄 在 15 一 35 岁 之 间 , 电 话 必须 符合 电话 号 码 的 格式 “密码 ”与 “确认 密码 ”必须 相等 。 
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学 生 信 息 输入 卡片 


学 


3-20 ”对 学 生 注册 信息 实施 验证 程序 的 界面 


2. 确定 设计 思路 

从 题目 要 求 可 知 ,“ 学 号 "限制 为 8 位 数码 ,可 以 使 用 正则 表达 式 约束 ;“ 姓 名 ”不 允许 为 
空 , 可 使 用 “不 允许 空白 "控件 约束 ;“ 年 龄 ”使 用 “范围 限制 "控件 约束 ;“ 电 话 ” 使 用 “正则 表 
达 式 ”约束 ;“ 密 码 ” 使 用 “不 允许 空白 "约束; 而且“ 密码 ”与 “确认 密码 ”之 间 用 “要 求 值 相 
等 "控件 约束 。 

3. 界面 设计 

在 MyTest3 项 目 中 新 建 一 个 Web 窗 体 ,命名 为 stuInput。 

首先 ,从 【工具 箱 ] 中 拖 动 控件 ,实现 界面 。 即 输入 标题 “学 生 信息 输入 卡片 ”, 并 简单 地 
调整 字体 和 位 置 。 

接着 从 工具 箱 中 的 HTML 类 工具 下 拖 动 一 个 3 行 4 列表 格 到 窗 体 中 ,按照 图 3-20 所 
示 的 格式 创建 “标准 ”控件 和 文字 。 

最 后 ,依次 把 文本 框 控件 的 ID 修改 为 xh,xm,age,phone,pswd,apswd。 并 正确 设置 
“性 别 ? 单 选 按钮 的 相关 属性 。 

4. 添加 验证 

1) 为 “学 号 ”文本 框 添加 验证 

从 工具 箱 的 “验证 ?栏目 下 拖 动 一 个 RegularExpressionValidator 控件 ,把 它 放 到 “学 
号 "文本 框 的 后 面 。 打 开 【 属 性 了 面板 ,设置 此 控件 的 Text 属性 为 “ * ”,ErrorMessage 为 “学 
号 必须 输入 8 位 数码 1”,ControlToValidate 属性 为 “xh”。 找 到 ValidationExpression 属性 ， 
单 击 后 面 的 小 按钮 ,启动 正则 表达 式 编辑 器 ,如 图 3-21 所 示 。 在 底部 的 【验证 表达 式 】 文 本 
框 中 输入 正则 表达 式 “[0-9]{8)”, 然 后 单 击 【 确 定 ] 按 钮 即 可 。 


3-21 为 控件 验证 添加 正则 表达 式 的 界面 
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2) 为 “姓名 ”文本 框 设置 验证 

从 工具 箱 的 “验证 ”栏目 下 拖 动 一 个 RequiredFieldValidator 控件 ,把 它 放 到 “姓名 ”文本 
框 的 后 面 。 打 开 【 属 性 】 面 板 , 设 置 此 控件 的 Text 属性 为 ** ”,ErrorMessage 为 “姓名 不 能 
为 空 !”,ControlToValidate 属性 为 “xmy”。 

3) 为 “年 龄 "文本 框 设置 验证 

从 工具 箱 的 “验证 ”栏目 下 拖 动 一 个 RangeValidator 控件 ,把 它 放 到 “年 龄 * 文 本 框 的 后 
面 。 打 开 [ 属 性 面板, 设置 此 控件 的 Text 属性 为 ** ”,ErrorMessage 为 “年 龄 必须 在 15 一 35 
之 间 !”，ControlToValidate 属性 为 “age”, Type 属性 的 值 为 “Integer”。 找 到 
MaximumValue 属性 ,设置 其 值 为 35; 找 MinimunValue 属性 ,设置 其 值 为 15。 

4) 为 “电话 ”文本 框 设置 验证 

从 工具 箱 的 “验证 ”栏目 下 拖 动 一 个 RegularExpressionValidator 控件 ,把 它 放 到 “ 电 
话 " 文 本 框 的 后 面 。 打 开 【 属 性 了 面板 ,设置 此 控件 的 Text 属性 为 * ”,ErrorMessage 为 “ 电 
话 号 码 格式 有 误 !”,ControlToValidate 属性 为 “phone”。 找 到 ValidationExpression 属性 ， 
单 击 后 面 的 小 按钮 ,启动 正则 表达 式 编辑 器 ,如 图 3-21 所 示 。 在 “标准 表达 式 ” 列 表 框 中 选 
择 “ 中 华人 民 共 和 国电 话 号 码 ”, 然 后 单 击 [确定 按钮 即 可 。 

5) 为 “密码 "文本 框 设 置 验证 

从 工具 箱 的 “验证 ”栏目 下 拖 动 一 个 RequiredFieldValidator 控件 ,把 它 放 到 “密码 ”文本 
框 的 后 面 。 打 开 【 属 性 面板 ,设置 此 控件 的 Text 属性 为 “ * ”, ErrorMessage 为 “密码 不 能 
为 空 !”,ControlToValidate 属性 为 “pswd”。 

6) 对 “密码 ”与 “确认 密码 "文本 框 的 输入 内 容 设置 对 比 的 验证 

从 工具 箱 的 “验证 ?栏目 下 拖 动 一 个 CompareValidator 控件 ,把 它 放 到 “确认 密码 ”文本 
框 的 后 面 。 打 开 [【 属 性 了】 面板 ,设置 此 控件 的 Text 属性 为 " * ”,ErrorMessage 为 “密码 与 确 
认 密 码 不 相同 !”,ControlToValidate 属性 为 "pswd”,ControlToCompare 属性 为 “apswd”。 

7) 添加 ValidationSummary 控件 集中 输出 出 错 信 息 

从 工具 箱 的 “验证 ?栏目 下 拖 动 一 个 ValidationSummary 控件 到 窗 体 的 适当 位 置 , 用 于 
集中 显示 整个 窗 体 中 的 输入 对 象 的 验证 结果 。 

5. 相关 的 代码 

完成 全 部 设置 后 ,stulnput. aspx 中 的 相关 代码 如 图 3-22 所 示 。 

6. 小 结 

运行 上 述 验证 程序 ,会 发 现 以 下 规律 。 

(1) 尽管 对 “学 号 ”限定 了 8 位 数码 的 验证 ,但 这 一 验证 并 不 控制 输入 空白 值 。 同 理 ,对 
电话 号 码 的 输入 限制 .年 龄 的 输入 限制 都 具有 同样 的 问题 。 如 果 和 希望 学 号 ,年龄 都 必须 输入 
数据 ,那么 还 需要 给 它们 添加 “不 允许 空白 ”的 验证 。 

(2) 各 个 验证 的 ErrorMessage 警示 信息 在 ValidationSummary 对 象 中 集中 输出 。 如 
果 不 添加 ValidationSummary 对 象 , 则 不 能 输出 出 错 信 息 。 

(3) 如 果 被 验证 的 窗 体 上 有 【取消 按钮 , 当 单 击 【取消 了 按钮 时 应 关闭 窗 体 而 不 进 
行 数据 验证 ,此 时 需要 设置 【取消 按钮 的 CausesValidation 属性 的 值 为 false, 放 弃 验 证 
功能 。 
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I! age Laneuage="C#" AutoEventfireup=ntruen CodeBenind="stulnput. aspx. cs" Inherits="WyTest3. stuInput' 网 
2 <IDOCTIPE html PUBLIC "-//W3C//DID XHTWL 1.0 Transitional//EN" 
: Ww 93 xhtnl 1 /DID/xhtnll-transitional dtd"> 

tp: /fwww.w3. org/ 1999/xhtnl" > 


《title) 无 标题 砚 人 title> 
Cstyle type="text/css"> 
stylel{ 
font-size: x-large; 
font-weight: bold; } 
style2 { } 
style4  { width 227px; } 
Style5 { width: 219px; } 
style>/head> 
hody> 
《form id="forml" runat="server"》 
div style="text-align: center"> 
《span clsss="stylel") 学 生 信息 输入 卡片 Yspan>cbr /> 
《table style="width:100%;"> 
《tr>Ktd class="style4"> 
学 昌 : 《asp:TextBox ID="zh” runat="server">C/asp;TextBox> 
asp: Regul arExpressionYal idator ID="RegularExpresl" runat="server" 


ControlToValidate="xh" Display="Dynanic" 

Errorllessage=" 学 吕 必 须 输入 8 位 孝 码 !“" 
25 ValidationExpression=" [0-9]{8}">》*#<fasp:Regulargxpressionyalidator> 
26 Cftd>ktd class="style5"> 
27 姓名 : 《asp:TextBox ID="zm" runat="server">C/asp: TextBox> 
2 如 《asp:RequiredFieldyalidator eqFl" runat="server" 
29 ControlToValidate="xm”Errorflessag:=" 姓 名 不 能 为 空 !" 冰 
30 fasp:RequiredPiel dyYslidator> 
131 各 tad>ktd> 性 别 : 《asp:RadioButtonList ID="xb" runat="server"> 
32i 《asp:ListItem) 胃 <fasp:ListIten> 
33 《asp:ListItem Selected="True"> 女 人 /asp:ListIten》 
34 《fasp:RadioputtonList>Gftd>Gtr> 
135 如 tr td class="style4"》 
36 年 龄 : 《asp:TextBox ID="age" runat="server ">C/ asp:TextBox> 
37 吕 《asp:Rangeyali dator II="RangeyYali dator1"” runat="server" 
3 ControlToValidate="age" Errorllessage=" 年 龄 必须 在 15-35 之 间 ! " 
39 Ilaxinmumyalue="35” MinimunVYalue="15" 
40 Type="Integer" ?skfasp:Rangeyalidator> 
有 浊 《td)Ktd class="style5"> 
42 电话 : 《asp:TextBox ID="phone" runat="server">C/ssp:TextBox》 
43 刁 asp' Regul arExpressionValidator 了 alidator2" runat="server" 
44 ControlToVali date="phone”Errorllessage='" 电 话 号 码 格式 有 误 !" 
45 ValidationExpression=" (\ (\d{3}\) |\4{3}-)?\d{8} "六 
446; fasp:RegularExpressionYalidator > td> 
47 《tdinbsp; Vtd> 
145 tr itr td class="style4"> 
49; 密码 : 《asp:TextBox ID="pswd" runat="sarver"></asp:TextBox> 
S00 《asp:Requiredpieldyalidator ID="Req2" runat="server" 
51 ControlToYalidate="pswd"”Errorllessags=" 室 码 不 能 为 空 ! " 冰 
52 Vasp: RequiredPieldValidator /td> 
53 折 td class="sty1e5"》 
54 确认 密码 : 《asp TextBox ID="apswd" runat=" "server">C/asp: TextBex> 
55 和 和 《asp:Compareyalidator ID="ComparsValidatorl" runat="server" 
56 ControlToC ompare="apswd" ControlToYali date="pswdn 
57 Errorllessage=" 密 码 与 确认 密码 不 相同 ! "Casp: ConpareYalidatcr> 
Ei td td nbsp; VYtr> 
590 <tr>Ktd class= ”style2 colspanc 3 >， 
60 《asp:Button ID="stuTest" runat="server" Text=" 测 试 " br 办。 
81 《asp:Yali datiohSunmary ID="YalidationSomnaryl" runat="server" /> 
B62 YtDY tr> 
53; table>Y div Wform> 


B4 Cfbody>C/htnl > 


3-22 ”对 学 生 注册 信息 控件 实施 验证 的 aspx 代码 


1. TextBox 控件 有 什么 作用 ? 如 何 获取 用 户 在 TextBox 文本 框 中 输入 的 数据 ? 

2. 如 何 修改 Button 控件 的 显示 信息 ? Button 控件 的 Click 事件 的 对 应 方法 存储 在 什 
么 位 置 ? Button 的 Click 方法 和 onClientClick 属性 有 什么 不 同 ? 

3. RadioButton 与 RadioButtonList 有 什么 区 别 ? 如 何 使 多 个 RadioButton 控件 的 选 
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中 项 互 斥 ? 

4. CheckBox 与 CheckBoxList 控件 有 什么 区 别 ? 如 何 获 取 CheckBoxList 的 选项 值 ? 

5. 什么 是 DropDownList 控件 ? 如 何 利用 可 视 化 方式 为 DropDownList 控件 赋予 选 
项 ? 如 何 获取 DropDownList 的 选 定 项 的 值 ? 

6. 如 何 利用 代码 为 DropDownList 控件 赋予 选项 ? DropDownList 控件 的 选项 可 以 来 
源 于 数据 表 的 字段 吗 ? 

7. HyperLink 控件 的 作用 是 什么 ? 与 <a href 之 有 什么 不 同 ? 

8. 什么 是 服务 器 验证 控件 ?在 服务 器 验证 控件 中 ,ErrorMessage 和 Text 属性 的 值 有 
什么 不 同 ? 

9.，RequiredFieldValidator 控件 的 作用 是 什么 ”如 何 利用 RequiredFieldValidator 控件 
监控 其 他 的 控件 ? 

10. 与 其 他 验证 控件 不 同 ,CompareValidator 控件 需要 同时 监控 两 个 控件 的 输入 数值 ， 
CompareValidator 控件 是 如 何 控 制 这 两 个 控件 的 ? 

11. 什么 是 正则 表达 式 ? 如 何 把 正则 表达 式 应 用 到 ASP.NET 的 控件 验证 中 ? 

12. ValidationSummary 控件 有 什么 用 途 ? 与 其 他 的 验证 控件 有 什么 不 同 ? 


仁 机 实 训 惠 


某 医 院 要 建立 一 套 医生 信息 管理 系统 。 已 知 医生 的 信息 包括 职工 号 、 医 生 姓 名 、 医 生性 
别 、 医 生生 日 .所 在 科室 、 医 生 专 长 .基础 工资 和 电子 邮件 地 址 。 

启动 VS2008 ,新 增 项 目 Test3 ,然后 在 此 项 目 中 完成 以 下 任务 ， 

(1) 新 建 一 个 窗 体 ,为 医生 信息 创建 一 个 输入 界面 ,要 求职 工 号 ,医生 姓名 、 医 生生 日 、 
电子 邮件 地 址 和 基础 工资 使 用 TextBox 控件 ,医生 性 别 使 用 RadioButton 控件 ,所 在 科室 字 
段 使 用 DropDownList 控件 .医生 专长 使 用 CheckBoxList 控件 设计 。 

(2) 为 窗 体 添加 Button 控件 , 当 单 击 Button 时 ,能 够 输出 上 述 控件 接收 到 的 所 有 信息 。 

(3) 为 上 述 控 件 添加 验证 控件 ,要 求 工 号 ,姓名 和 性 别 为 必须 输入 的 字段 ,而 且 工 号 限 
制 为 8 位 数码 ,电子 邮件 地 址 符合 Email 的 格式 规则 ,基础 工资 限定 在 500~8000 之 间 。 

(4) 最 后 通过 ValidationSummary 控件 集中 输出 验证 结果 信息 。 


学 习 要 点 

本 章 主要 学 习 ASP.NET 网 页 布局 的 方法 。 要 求 了 解 母 版 页 的 概念 .主题 文件 的 概念 、 
动态 网 站 的 导航 技术 、 局 部 刷新 技术 、 应 用 客户 端 代码 增添 网 页 特效 的 技术 。 本 章 要 求 重点 
关注 以 下 内 容 : 

。 主题 文件 和 CSS 文件 的 创建 与 使 用 。 

。 母 版 页 的 创建 与 使 用 ,重点 关注 基于 Photoshop 布局 实现 母 版 页 。 

。 网 站 导航 技术 中 的 SiteMapPath .TreeView 和 Menu 导航 技术 。 

。 AJAX 中 ScriptManager 与 UpdatePanel 的 应 用 。 


(4.1 页 面 对 象 的 外 观 设计 
SA 


前 面 多 次 指出 ,网 页 是 文本 与 图 像 等 对 象 按照 一 定 的 格式 组 织 起 来 的 综合 性 文档 , 随 
着 网 页 交互 能 力 的 出 现 和 发 展 ,动态 网 页 技术 日 益 普 及 ,Web 窗 体 中 的 控件 成 为 网 页 组 成 
内 容 中 的 重要 对 象 。 传 统 的 静态 网 页 仅 关 注 文本 和 图 像 内 容 , 对 交互 能 力 的 考虑 较 少 。 因 
此 ,面向 静态 网 页 技术 的 CSS 样式 文件 是 聚焦 于 文本 、 图 像 以 及 其 他 静态 网 页 元 素 的 外 观 
设置 的 ,而 对 Web 窗 体 控件 的 外 观 设 置 , 则 是 通过 VS2008 的 主题 文件 (也 称 外 观 文件 ) 来 
实施 的 。 主 题 文件 和 CSS 文件 是 当前 设置 动态 网 页 外 观 的 重要 工具 ,统称 为 网 页 的 主题 。 
这 些 文件 通常 被 放 在 App_Themes 文件 夹 中 。 


4.1.1 VS2008 对 CSS 文件 的 支持 


1. 新 建 CSS 文件 

在 “解决 方案 资源 管理 器 ”中 右 击 项 目 名 称 , 在 快捷 菜单 中 选择 [添加 】>【 新 建 项 】， 
选择 [样式 表 】 ,给 予 命名 后 则 创建 一 个 样式 表 文 件 ,并 处 于 样式 表 的 编辑 状态 ,如 图 4-1 
所 示 。 

系统 默认 提供 了 一 个 “body{)”, 表 示 要 对 网 页 的 主体 (body) 部 分 设置 默认 的 字体 、 字 
形 、 字 号 ,色彩 等 属性 。 把 光标 放 在 “body{}” 的 花 括 号 中 ,然后 单 击 【 属 性 面板 中 Style 属 
性 后 面 的 回 按 钮 ,打开 【修改 样式 ] 对 话 框 , 如 图 4-2 所 示 。 

在 此 对 话 框 中 ,可 完成 针对 body 的 样式 设计 。 

对 于 CSS 样式, 既 可 以 针对 HTML 已 有 的 对 象 类 型 (如 设置 body、p、td、 th、br、 
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a 等) 重新 设置 其 外 观 ,也 可 以 新 建新 的 样式 类 。 注 意 ,新 建 的 样式 类 以 英文 句号 起 始 , 也 可 
以 直接 从 其 他 的 CSS 文件 中 粘贴 代码 到 当前 的 CSS 文件 中 。 

下 面 的 代码 就 是 “ 马 秀 月 的 教学 服务 平台 ”使 用 的 公共 样式 文件 main. css 的 内 容 ,如 
图 4-3 所 示 。 

从 图 4-3 可 以 看 出 ,本 CSS 文 件 首先 定义 了 整个 body 的 默认 字体 的 相关 信息 ,接着 定 
义 了 超 链 接 的 四 个 状态 的 字体 信息 , 随 之 新 建 了 5 个 样式 类 ,分 别 是 各 级 标题 的 样式 和 正文 
的 样式 。 

最 后 ,保存 CSS 文 件 。 


文件 日 妨 生 日 视 国 W 项目 (P) 生成 (8) 涯 (D) 工具 D 有 9 
a 
Fr MA IE 4 


wea oes 
2 


vx 


font-fumily: 守 | 
font-size; 


font-weight: bold 
font-style: | 


font-variant: 
text-transforn; 
ealer 


font-size: 12pt fontweieht. bold; fontrstyle noraal, 


Cj] 


图 4-2 【修改 样式 ] 对 话 框 
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body { text-indent: 32; line-height: 150%; text-align: left; 
font-family: 宋体 ;font-size: 12pt; color: #006699; margin: 0; 


a:link { font-size: 10.5pt; line-height: 18px; color: #0000FF; 
text-decoration: underline; 


ai:visited { font-size: 10.5pt; line-height: 18px; 
color: #0000FF; text-decoration: nderline; 


a:hover { font-size: 10.5pt;line-height: 18px; 
color: #FF0000; text-decoration: underline; 
background-color: #00f000; 


a:active { font-size: 10.5pt; line-height: 18px; 
color: #FF0000; text-decoration: underline; 


.btl { font-family: 隶书 ; font-size: 32px; color: 守 F0000; 
font-weight: bold; text-align:center,margin-top:?; 
margin-bottom:2;} 


.bt3 { font-family: "宋体 "; font-size: 14pt; line-height: 28px; 
color: #8000ff; font-weight: bold; 


.bt4 { font-family: "楷体 _GB2312"; font-size: 13pt;color: #0000ff; 
font-weight: bold; 


.bt2 { font-fanily: "华文 中 宋 ";， font-size: 20px;line-height: 24px; 
color: #ff00ff; font-weight: bold; 


.TXT { font-family: 宋体 ; font-size: 12pt; color: #000080; text-align: left; 
text-indent: 32; line-height: 150%; margin: 0; 


图 4-3 典型 CSS 文件 内 容 的 示意 图 


2. 在 动态 网 页 设计 时 应 用 CSS 文件 
在 VS2008 的 aspx 的 设计 视图 下 ,使 用 菜单 【视图 了 -并 应 用 样式 】, 则 打开 【应 用 样式 】 
面板 ,如 图 4-4 所 示 。 


从 中 选择 按钮 [附加 样式 表 】 然后 选择 CSS 文件 , 即 可 把 。 ES 
CSS 文 件 链接 到 当前 动态 网 页 中 。 此 时 CSS 样式 文件 中 针对 | 生生 
<<body>> .<p>>.<a> 的 格式 定义 会 自动 生效 。 要 使 用 新 定义 。 | 站 _ 
的 样式 类 , 则 只 须 先 选 定 文字 ,再 从 这 个 面板 中 选择 对 应 的 样式 。 | 
即 可 。 ®.stylel 

©® style? 

4.1.2 主题 文件 ae 

主题 文件 是 VS2008 针对 自己 内 血 控 件 的 外 观 和 格式 而 专门 。 | 
设计 的 一 种 控制 性 文档 。 EE 

1. 新 建 主 题 文 件 图 4-4 VS2008 的 [应 用 

在 "解决 方案 资源 管理 器 "中 右 击 项 目 名 称 ,在 快捷 菜单 中 先 样式 面板 


择 [ 添 加 】>【 新 建 项 】, 选择 “外 观 文件 ”, 给 予 命名 MySkin 后 , 系 
统 询问 是 否 创建 在 “App_Themes” 主 题 下 ,回答 “是 ”后 就 会 创建 一 个 主题 文件 ,并 且 处 于 此 
主题 文件 的 编辑 状态 ,如 图 4-5 所 示 。 

在 编辑 状态 输入 控件 类 名 ,并 对 控件 的 前 景色 (Forecolor) .背景 色 (BackColor) .字体 、 
字形 和 字号 等 进行 设置 。 编 辑 的 代码 如 图 4-5 所 示 。 从 图 4-5 可 知 ,主题 文件 所 使 用 的 格 


式 描述 方法 与 CSS 文件 基本 相同 。 

设置 完毕 ,保存 并 关闭 主题 文件 。 

2. 对 当前 页 面 应 用 主题 文件 

在 aspx 的 设计 视图 下 , 单 击 当 前 页 面 的 空白 处 ,使 [属性 ] 面 板 以 DOCUMENT 作为 当 
前 对 象 ,此 时 修改 其 属性 StyleSheetTheme 的 值 为 主题 文件 的 名 称 ,例如 “MySkin”, 按 
Enter 键 后 会 发 现 相 关 控 件 的 外 观 都 发 生 了 变化 。 

3. 使 整个 网 站 应 用 主题 文件 

如 果 整 个 网 站 都 希望 使 用 已 经 制作 的 主题 文件 , 则 需要 修改 web. config 的 配置 信息 。 
即 打 开 此 文档 ,在 其 过 System. web 记 与 过 /System. web 二 之 间 增 加 一 行 : 


< pages theme = "主题 文件 名 "/> 


MyTest3 - Microsoft Visual Studio[ 管 理 员 ) 
文中。 明和 日 ， 议 国 VW 项 生成 @) 主 #D) I 内 D (9 OW WM 
MM J Md 
ET TE EFFrE EE 要 
shulnputaspxcs | 怨 始 列 -x v7 
Myskinsskin"| -x EE, 

| 中 
2 对 板 。 以 下 外 观 公 作 为 示人 人。 < 
4 1 命名 风 和 件 外 观 。SkaaTd 的 宅 义 让 隆 一 ,因为 在 同 -主题 中 不 允许 一 个 按 科 类 型 有 重 四 


server” SkisTd-" gridviesSkin" BackColor="White” > 
nStyle Backcolor="Hlue" /> 


kinTde 在 同一 主题 中 每 个 控件 类 型 只 允许 有 一 个 默认 的 控件 外 观 。| 本 
Insgelrl=""/innges/inogel jpg” /> 


006600 Fo pt"/> 
color=#008000 Backolor="lightbloe"” 


图 4-5 创建 主题 文件 的 操作 界面 


您 母 版 页 的 概念 


从 众多 网 站 包含 的 大 量 网 页 看 ,一 个 网 站 中 包含 的 大 部 分 网 页 都 具有 相似 的 框架 结构 ， 
只 有 部 分 区 域 是 变化 的 。 因 此 ,在 网 站 建设 过 程 中 ,针对 框架 的 修改 将 会 引发 大 量 页 面 的 修 
改 , 其 工作 量 非常 大 。 为 解决 这 一 问题 ,Dreamweaver 提出 了 模板 技术 ,而 VS2008 则 使 用 
母 版 技术 。 


4.2.1 母 版 页 与 内 容 页 的 概念 


所 谓 母 版 页 ,就 是 一 个 网 站 的 通用 框架 页 面 ,这 个 页 面包 括 了 网 站 中 一 组 页 面 的 整体 结 
构 和 页 面 布局 ,并 在 此 页 面 中 为 部 分 可 填充 区 域 设置 特定 的 标记 。 只 有 被 标记 的 区 域 才 可 
以 被 它 派生 的 内 容 页 填 人 内 容 。 

当 一 个 母 版 页 完成 后 ,就 可 以 基于 母 版 页 创建 内 容 页 。 从 设计 视图 上 看 ,内 容 页 是 包括 
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了 整个 网 页 结构 的 页 面 。 在 这 个 页 面 上 只 有 母 版 页 预先 标记 的 区 域 才 是 可 以 被 编辑 的 ,在 
标记 区 域 中 可 以 输入 新 的 ,个 性 化 的 内 容 。 而 事实 上 ,内 容 页 中 仅 包含 一 个 到 母 版 页 的 链接 
和 这 个 内 容 页 的 个 性 化 内 容 。 

由 于 多 个 内 容 页 共享 母 版 页 ,使 得 共性 化 的 页 面 布 局 和 结构 仅 有 一 份 。 因 此 ,使 用 母 版 
页 可 以 便利 地 统一 网 站 中 相关 页 面 的 风格 ,对 网 站 中 页 面 框架 和 布局 的 修改 也 通过 母 版 页 
实现 ,能 够 做 到 “一 次 修改 ,惠及 全 体 ”, 从 而 极 大 地 提升 网 页 设计 的 效率 。 


4.2.2 创建 母 版 页 


创建 母 版 页 可 以 分 为 以 下 几 个 阶段 : 新 增 母 版 页 文件 ,完善 母 版 页 ,保存 母 版 页 。 

1. 新 增 母 版 页 文件 

右 击 “ 解 决 方案 资源 管理 器 ”中 的 项 目 名 称 ,在 快捷 菜单 中 选择 [添加 】->【 新 建 项 】 ,然后 
在 [添加 新 项 ] 对 话 框 中 选择 “ 母 版 页 ”, 并 命名 为 MySite. Master, 然 后 单 击 【添加 按钮 , 系 
统 会 自动 建立 MySite. Master 母 版 页 ,并 在 主 工作 区 打开 此 文档 ,进入 到 编辑 状态 。 

2. 完善 母 版 页 

回 到 母 版 页 的 [设计 了 视图 下 ,会 发 现存 在 一 个 ContentPlaceHolder 1 控件 ,可 先 删除 此 


童 OAW 帮助 
(MM A IN MN 
科 马 | 了 了 至 | 三 全 |jXHTML10Trenste 7 | 人 @ ;四 ” 


Contentlacenolgel "| 
辐 如 2 方 ^ 
2 
1 
Rev HX 
>| Contentpla» 
了 | 融 妃 夺 
Gt | 分 | 四 源 | [4][<dv> |[<aspcontentplaceloldersC.> |)] pe 加 | 
| | | 
Ea 行 16 列 34 Ch34 


4-6 创建 母 版 页 的 操作 界面 


从 [工具 箱 】 中 的 HTML 栏目 拖 动 Table 控件 到 <<div 之 之 间 ,形成 一 个 表格 (Table) 对 
象 。 通 过 适当 调整 表格 中 单元 格 的 数目 ,合并 与 拆 分 表格 中 的 单元 格 ,改变 单元 格 的 宽度 和 
高 度 ,最 终 把 整个 屏幕 划分 为 若干 个 区 域 。 例 如 有 Logo 区 .菜单 区 .导航 区 、 目 录 区 、 主 工 
作 区 、 底 部 的 版 权 区 等 。 最 后 可 适当 设置 母 版 的 背景 ,为 Logo 区 插入 处 理 好 的 图 片 ,适当 
配置 菜单 区 、 导 航 区 的 信息 。 

从 【工具 箱 了 的 【标准 了 栏目 下 拖 动 ContentPlaceHolder 控件 , 放 到 母 版 上 的 每 个 需要 在 
内 容 页 中 更 新 的 区 域 。 例 如 ,为 母 版 页 的 目录 区 和 主 工作 区 添加 ContentPlaceHolder 控 
件 , 系 统 会 为 每 个 控件 依次 命名 ,使 之 成 为 若干 个 独立 的 ContentPlaceHolder 对 象 。 

完善 母 版 页 的 过 程 中 ,可 以 应 用 已 经 做 好 的 CSS 样式 文件 和 主题 文件 。 
最 后 保存 母 版 页 。 
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4.2.3 创建 内 容 页 


1. 基于 母 版 页 建立 内 容 页 

在 解决 方案 资源 管理 器 中 , 右 击 某 个 母 版 页 文件 ,从 其 快捷 菜单 中 选择 [添加 内 容 页 】, 
系统 将 立即 创建 一 个 基于 此 母 版 页 的 内 容 页 。 

此 时 应 立即 右 击 新 的 内 容 页 文件 ,并 对 其 重 命名 。 

切换 到 内 容 页 的 【设计 视图 ,会 发 现 新 生成 的 内 容 页 与 母 版 页 完全 相同 ,只 是 部 分 区 域 
为 ContenPlaceHolder 区 域 。 

2. 完善 内 容 页 

可 在 内 容 页 的 ContenPlaceHolder 区 域 中 输入 此 内 容 页 所 需 的 文本 、 图 像 ,甚至 是 Web 
窗 体 的 控件 。 

在 内 容 页 中 ,可 以 独立 地 使 用 样式 文件 或 者 主题 文件 ,从 而 使 页 面 得 到 美化 ,更 有 特色 。 

最 后 ,保存 内 容 页 。 

注意 ; 对 母 版 页 的 修改 将 会 影响 到 所 有 的 相关 内 容 页 。 如 果 需 要 修改 母 版 页 ,请 一 定 
不 要 破坏 和 改变 其 ContentPlaceHolder 控件 的 名 称 , 否 则 可 能 导致 相关 的 内 容 页 出 现 
混乱 。 


4.2.4 基于 Photoshop 切片 创建 母 版 页 


在 网 页 开发 的 实际 工作 中 ,为 使 页 面 实现 比较 协调 、 美 观 的 效果 ,通常 不 直接 使 用 表格 
和 层 实现 布局 ,而 是 借用 Photoshop 或 Fireworks 实施 网 页 的 布局 ,制作 母 版 页 ,并 利用 母 
版 页 建立 内 容 页 。 

1. 以 Photoshop 绘制 网 页 页 面 

利用 Photoshop 的 选区 与 粘贴 文字、 图 层 样式 .自由 变换 等 技术 ,绘制 网 页 页 面 ,使 之 
达到 风格 明确 .协调 美观 的 效果 。 然 后 保存 此 psd 文件。 

2. 对 布局 页 面 实施 切片 

拼合 图 层 , 然 后 利用 Photoshop 的 切片 工具 切割 图 片 ,形成 若干 切片 。 有 意识 地 制作 出 
菜单 区 ,目录 区 , 主 工作 区 等 区 域 。 例 如 ,制作 如 图 4-7 所 示 的 效果 。 

其 中 “用 户 登 录 ” 下 面 的 10 号 切片 为 纯色 区 域 ,可 在 右 击 此 切片 后 利用 【编辑 切片 选项 】 
命令 将 其 修改 为 “无 图 像 模 式 ,并 设置 其 背景 为 当前 该 区 域 的 颜色 。 

3. 保存 为 Web 格式 

完成 切片 操作 后 ,选择 [文件 ]->【 保 存 为 Web 所 用 格式 3 命令 ,在 [将 优化 结果 存储 为 】 
对 话 框 中 ,选择 [保存 类 型 为 “HTML 和 图 像 ”, 在 [设置] 中 选择 其他”, 从 而 打开 [输出 设 
置 ] 对 话 框 。 

在 [输出 设置 对 话 框 中 的 HTML 选项 卡 上 ,设置 【结束 所 有 标记 】 复 选 框 有 效 ; 在 【 切 
片 3) 选 项 卡 上 ,把 [切片 输出 ] 设 置 为 “生成 CSS”, 表 示 以 CSS 十 DIV 方式 实现 布局 。 
最 后 , 回 到 [将 优化 结果 存储 为 ] 对 话 框 中 ,设置 文件 名 ,并 保存 此 Web 页 面 。 
此 时 将 生成 一 个 HTML 文档 和 一 个 images 文件 夹 ,在 images 文件 夹 中 包含 所 有 切片 
的 图 像 文 件 。 
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4-7 利用 Photoshop 的 切片 布局 页 面 


4. 在 VS2008 中 处 理 母 版 页 


1) 把 Photoshop 布局 的 页 面 导入 到 VS2008 母 版 页 
首先 ,把 前 面 生成 的 Images 文件 夹 复制 到 VS2008 项 目的 子 文件 夹 中 。 注 意 Images 


文件 夹 与 aspx 文件 处 于 同 级 文件 夹 中 。 


其 次 ,在 VS2008 的 解决 方案 管理 器 中 ,新 建 母 版 页 ,并 切换 到 [ 源 ] 视 图 下 , 先 删除 那个 


多 余 的 ContentPlaceHolder 控件 。 


最 后 ,以 记事 本 打开 Photoshop 生成 的 HTML 文件 ,把 过 style type 王 "text/css" 过 至 
三 /style 二 之 间 ( 含 这 两 条 语句 ) 的 内 容 复 制 到 母 版 页 的 二 head 记 与 之 /head 志 之 间 , 可 以 放 在 


<</title> 的 后 边 。 把 HTML 文件 中 过 !-- Save 
for Web Slices -- 之 至 到 !-- End Save for Web 
Slices -- 之 间 的 内 容 复 制 到 母 版 页 的 过 form 
runat 一 "Server" 二 一 /form 二 之 间 。 

2) 在 VS2008 中 分 析 页 面 的 构成 区 域 

首先 ,切换 到 母 版 页 的 【设计 视图。 在 母 
版 页 视图 下 ,观察 布局 页 面 的 各 个 构成 区 域 。 
此 时 母 版 页 的 布局 如 图 4-8 所 示 。 

从 图 4-8 可 以 看 出 , 共 设 置 了 5 个 区 域 。 
号 区 为 菜单 区 ,2 号 区 为 用 户 信息 区 ,3 号 
区 作为 目录 区 ,4 号 区 是 信息 区 ,5 号 区 是 版 
权 区 。 

以 鼠标 单 击 2 号 区 ,发 现 可 以 直接 输入 数 
据 , 而 且 不 影响 2 号 区 域 的 原 背景 颜色 。 


时 用 户 得 未 


国 


图 4-8 以 Photoshop 切片 实现 母 版 页 的 
分 区 示意 图 


3) 处 理 带 有 图 片 背景 的 区 域 

以 鼠标 单 击 1 号 区 ,会 发 现 此 时 该 区 域 被 一 Img 占 位 ,如 果 直 接 输入 文字 ,该 Img 就 会 
被 文字 取代 ,将 会 导致 2 号 区 的 背景 消失 ,成 为 纯 白 色 , 与 周边 的 整体 极 不 协调 。 为 此 需要 
把 1 号 区 域 中 填充 的 Img 转化 为 此 区 域 的 背景 色 。 主 要 操作 如 下 。 

@ 单 击 1 号 区 域 的 Img, 从 [属性] 面板 中 找到 其 src 属性 ,选中 其 值 *images/mmmm 
_05. gif” 后 执行 复制 ,然后 删除 1 号 区 域 的 img 对 象 。 

@ 根据 [设计 】 视 图 底部 的 提示 条 ,知道 此 区 域 对 应 的 层 对 象 是 过 div# mmmm-05 二 ， 
如 图 4-9 所 示 。 


mn ， 
马 设 计 | 口 拆 分 | 回 源 4) <html>] <body> ||<formsform1> ||<dive_01>|| <divarnmmm-05>| [<img>| | 


图 4-9 VS2008 设计 视图 底部 的 提示 条 


因此 切换 到 其 [ 源 ] 视 图 下 ,在 二 style 二 区 域 中 找到 针对 #mmmm-05 的 样式 定义 ,为 这 
个 样式 添加 一 行 语句 :“background-image:url(images/mmmm_05. gif) ;”, 如 图 4-10 所 示 。 


51 | mmmm-05 { 


52 position: absolute; 
53: left:18px; 

Sd: top:192px; 

55: width:991px; 

56 hei eht :S55px; 


7 backeround-image: url (images/mmmm_05. gif); 


图 4-10 对 层 对 象 背 景 的 设置 


注意 : url 后 括号 中 的 文件 名 就 是 前 面 复制 的 那个 image 的 src 的 信息 。 

最 后 ,切换 回 【 设 计 ] 视 图 ,对 3 一 5 号 区 域 都 进行 同样 的 处 理 。 

注意 : 对 Photoshop 布局 的 网 页 ,常常 需要 对 其 数据 输入 区 域 实施 背景 图 片 处 理 。 为 
减少 这 一 工作 量 ,在 以 Photoshop 绘制 页 面 时 ,通常 尽 可 能 对 未 来 的 数据 输入 区 使 用 纯色 
(如 2 号 区 域 ) ,以 便 在 Photoshop 切片 阶段 就 把 该 区 域 设 置 适当 的 背景 色彩 ,从 而 把 图 片 
删除 。 

5. 添加 菜单 项 与 版 权 页 

为 母 版 页 的 1 号 区 域 添加 菜单 项 ,并 为 菜单 项 建立 超 链接 。 此 时 如 果 还 没有 下 级 网 页 
文件 , 则 可 预先 规划 相关 的 文件 名 ,并 建立 相应 的 链接 。 

在 母 版 页 的 5 号 区 域 输入 版 权 页 信息 。 为 达到 较 好 的 效果 ,在 此 可 以 使 用 滚动 字幕 等 
技术 。 

此 时 可 对 母 版 页 施加 CSS 文件 和 主题 文件 ,限定 母 版 页 中 文本 和 控件 的 样式 。 

6. 添加 内 容 页 的 可 编辑 区 域 

在 母 版 页 的 2 号 区 3 号 区 .4 号 区 添加 ContenPlaceHolder 控件 ,分 别 建立 3 个 可 编辑 


区 | 


域 。 
最 后 ,保存 母 版 页 。 
7. 应 用 母 版 页 创建 内 容 页 
在 解决 方案 管理 器 中 右 击 刚刚 创建 的 母 版 页 ,在 快捷 菜单 中 选择 “添加 内 容 页 ”, 就 添加 
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了 一 个 内 容 页 。 
重 命名 此 内 容 页 ,然后 在 可 编辑 区 域 中 输入 此 内 容 页 的 个 别 化 内 容 。 
以 此 方式 可 以 快速 建立 一 系列 的 内 容 页 ,快捷 地 生成 一 个 网 站 。 


43 网 站 导航 技术 


在 网 站 设计 中 ,优美 .清晰 的 导航 能 够 引导 浏览 者 快捷 便利 地 欣赏 网 站 内 容 ,为 网 站 增 
色 不 少 。 网 站 导航 的 前 提 是 设计 者 为 系统 提供 一 个 网 站 地 图 ,说 明 网 站 中 包含 的 内 容 文件 
之 间 的 逻辑 关系 ,然后 采取 适当 的 技术 把 网 站 地 图 呈现 出 来 。 为 此 ,VS2008 提供 了 网 站 地 
图 SiteMapPath TreeView 和 Menu 等 关键 技术 。 


4.3.1 站 点 地 图 


1. 什么 是 站 点 地 图 

站 点 地 图 是 VS2008 提供 的 一 种 文档 ,该 文档 用 于 说 明 网 站 中 各 个 网 页 文件 含义 ,以 及 
网 页 之 间 的 逻辑 关系 、 链 接 关 系 。 

从 本 质 上 看 ,站 点 地 图 是 一 个 XML 文档 。 其 文件 扩展 名 是 sitemap 。 

2. 新 建站 点 地 图 

在 “解决 方案 管理 器 "中 右 击 项 目 名 称 ,在 快捷 菜单 中 选择 [添加 】>【 新 建 项 】, 在 [添加 
新 项 对话 框 中 选择 [站 点 地 图 】 ,采用 默认 的 站 点 地 图 名 称 ( 即 “Web. sitemap”) ,然后 单 击 
【添加 了 按钮 ,就 向 项 目 中 添加 了 一 个 站 点 地 图 文档 。 

此 时 ,系统 在 主 工作 区 打开 这 个 站 点 地 图 文件 ,开发 者 可 在 此 文档 中 输入 站 点 的 文档 信 
息 , 如 图 4-11 所 示 。 


Microsoft Visual Studio( 管 理 员 ) 


文件 昌 ” 锯 济 昌 ”视图 VY) 项目 PB) 生成 @) 涯 z(D) XMLO 工具 D 测 汉 () 
富 口 W) 帮助 由 


Db 


4-11 新 建站 点 地 图 文件 的 界面 图 


3. 编辑 站 点 地 图 
从 图 4-11 的 站 点 地 图 代码 中 可 以 看 出 ,站 点 地 图 文档 的 基本 语句 格式 为 ， 
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< siteMapNode url = "链接 文件 之 名 " title = "链接 的 标题 " description = "描述 信息 " /> 


因此 ,可 以 按照 这 个 格式 把 站 点 中 包括 的 文档 及 其 相互 关系 在 此 文档 中 说 明 。 
一 个 典型 的 站 点 地 图 文件 的 内 容 如 图 4-12 所 示 。 


li: 《9?xml version="1.0”encoding="utf-8”?> 
2 口 《sitellap xmlns="http://schemas. microsoft com/AspNetfSitellal -File-1.0" 六 
《sitelapNode url="index. aspx”title=" 首 内 ” description=" 首 内 " 
《sitellapNode url="ldfe. aspx”title=" 领导 风采 ” i "领导 
<sitellapHode url="zhangp. aspx" title=" 张 平 " deseriptionE 能 六 
《sitellapHode url="]lilu apsx”title=" 李 五” deseription=" 副 
《sitelapNode url="cuiguang. aspx" title=" 鹤 广 志 "” descriptionr " 副 核 长 ” 产 
《sitellaplode url="maxiaop. aspx”title=" 马 晓 萍 ” deseription=" 副 校长 ”/> 
《sitelapHode url="zhaopl. aspx” title=" 赵 平安 " description=" 教 务 王 任 " /> 
sitelapHode> 
《sitejlapNode url=" zj aspx" title=" 组 织 机 构 " description= "组 织 机 构 " > 
<sitelapHode url="zzxb. aspx" 
<sitellapHode url="zzjw. apsx" ti 


<sitellapHode url="zzcw. aspx" ti "description=" 财 务 处 " 从 
《sitellapNode url="zzkj. aspx" description=" 科 技 处 ”/ 
<sitellapHode url="zshq. aspx" title=" > description=" 后 拐 处 " 人 

人 sitellapyode> 

《sitejlapNode url=" X58r. aspx" ti t1e=" 学 生 工 作 " description=" 学 生 工作 "> 
<sitellapHode url="xsdzb. aspx " title= "学 生 党 支部 description= "党 小 组 "” /> 
<sitelapHode url="xstw. apsx" ,title=" "团委 " description=" "团委 " > 
《sitellapNyode url="xssxd. aspx" title=" "少先队 ” description=" "少先队 ” 77 
《siteMapHode url="xsxsh. aspx”title=" 学 生 会 ” description=" 学 生 会 ”/》 

sitelapHode> 
上 人 sitellapNode> 

25: tC/fsitelap> 


” description=" 教 务 处 " /> 


图 4-12 站 点 地 图 文件 的 内 容 


从 图 4-12 可 知 ,此 网 站 的 文档 分 为 三 组 ， 第 一 组 是 领导 人 物 的 介绍 ， 在 文档 中 处 于 
第 4~10 行 ; 第 二 组 是 关于 组 织 机 构 的 介绍 ,在 文档 中 处 于 第 11~17 行 ; 第 三 组 是 关于 学 
生 工作 的 文档 ,在 文档 中 处 于 第 18~23 行 。 

4. 特别 说 明 

站 点 地 图 文件 制作 成 功 后 ,可 以 为 SiteMapPath .TreeView 和 Menu 等 控件 导航 手段 
提供 支持 。 

如 果 需 要 ,可 以 利用 语句 “二 siteMapNode siteMapFile 二 "站 点 地 图 文件 名 . siteMap" /二 ” 
把 另外 的 站 点 地 图 文件 嵌入 到 当前 文档 的 任意 位 置 。 


4.3.2 SiteMapPath 控件 导航 


1. 应 用 SiteMapPath 控件 显示 导航 

现在 为 “校长 办 公 室 ? 设 计 网 页 ,并 在 其 中 添加 SiteMapPath 控件 ,观察 效果 。 

在 “解决 方案 管理 器 "中 右 击 项 目 名 称 ,在 快捷 菜单 中 选择 [添加 】>【 新 建 项 】 ,然后 选择 
【Web 窗 体 】 ,命名 为 zzxb. aspx, 就 添加 了 一 个 名 字 为 zzxb. aspx 的 Web 窗 体 。 

从 [工具 箱 ] 的 [导航 ] 栏 目下 把 SiteMapPath 控件 添加 到 页 面 的 适当 位 置 。 

预览 此 页 面 ,观察 效果 ,其 结果 如 图 4-13 所 示 。 


从 图 4-13 可 知 ,系统 立即 列 出 了 当前 网 页 在 站 点 地 图 中 的 逻辑 关系 ,而 且 具 备 了 跳 转 
到 其 他 页 面 上 的 超 链接 。 


hv 
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2. SiteMapPath 控件 的 属性 设置 

单 击 SiteMapPath 控件 右上 角 的 小 图 标 ,可 以 展开 菜单 。 利 用 此 菜单 可 以 方便 地 选择 
【自动 套用 格式 】 ,改变 此 控件 的 显示 形式 。 

在 选中 SiteMapPath 控件 的 状态 下 ,还 可 使 
用 其 属性 “PathSeparator” 改 变 站 点 之 间 的 分 隔 符 
(默认 是 “之 ”) ,利用 属性 “PathDirection 改变 显 
示 顺 序 。 

注意 : SiteMapPath 控件 会 自动 调用 站 点 地 图 4-13 站 点 导航 的 效果 图 
图 文件 Web. sitemap, 不 需 进 行 任何 链接 设置 ; 如 果 站 点 地 图 文件 的 名 称 不 是 Web. 
sitemap, 则 会 导致 SiteMapPath 控件 失效 。 

包含 SiteMapPath 控件 的 页 面 应 该 使 用 站 点 地 图 中 声明 的 某 个 文件 名 ,而 且 要 严格 保 
证 正确 。 例 如 ,本 例 中 使 用 的 zzxb. asp 就 是 站 点 地 图 中 “校长 办 公 室 ” 对 应 的 网 页 文件 的 
名 称 。 

把 SiteMapPath 控件 嵌入 到 母 版 页 中 ,效果 更 佳 。 


4.3.3 TreeView 控件 导航 


1. 应 用 TreeView 控件 显示 导航 

下 面 将 为 “教务 处 ”设计 网 页 ,并 在 其 中 添加 SiteMapPath 控件 ,并 观察 效果 。 步 又 如 下 ， 

(1) 在 项 目 中 新 增 " Web 窗 体 ? 或 “内 容 页 ”, 命 名 为 zzjw. aspx。 

(2) 从 [工具 箱 ] 的 [导航] 栏目 下 把 TreeView 控件 添加 到 页 面 的 适当 位 置 。 

(3) 从 [工具 箱 ] 的 [数据 ] 栏 目下 把 SiteMapDataSource 控件 添加 页 面 的 任意 位 置 ,并 
利用 [属性 了 面板 设置 其 ID 为 smsl ,其 效果 如 图 4-14 所 示 。 

(4) 单 击 SiteMapPath 控件 右上 角 的 小 图 标 ,可 以 展开 一 个 小 菜单 。 利 用 此 菜单 可 以 
方便 地 选择 【自动 套用 格式 】 ,改变 此 控件 的 显示 形式 。 

(5) 在 小 菜单 中 [选择 数据 源 ] 下 拉 式 列表 框 中 选择 smsl 数据 源 。 

(6) 预览 此 页 面 ,观察 效果 ,最 终 效 果 如 图 4-15 所 示 。 


本 ap rbasp El 


| Laspitreeviews Treeviewd] 
上 


日 
局 父 级 1 | 去 后 式 . 
叶 1 


SiteMapDataSource - SMSL 


图 4-14 TreeView 导航 效果 图 图 4-15 TreeView 导航 的 效果 图 
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2. TreeView 控件 的 属性 设置 

TreeView 控件 通常 用 来 以 树 形 结构 显示 分 层 数 据 的 情形 ,利用 TreeView 控件 不 仅 可 
以 实现 站 点 导航 ,而 且 可 以 显示 XML、 表 格 和 关系 数据 库 的 内 容 。 

对 于 TreeView 对 象 ,常常 可 以 通过 C# 语句 实 现 编程 。 假 设 TreeView 对 象 的 名 称 为 
tv1, 则 常用 的 关键 语句 有 : 


TreeNode tn = new TreeNode( ); // 创 建新 的 TreeNode 结 点 ; 

tn. value= 字符 串 数据 ; // 为 结 点 赋予 显示 信息 ; 

tv. Nodes. Add( tn); // 把 新 结 点 tn 作为 tv 的 根 结 点 ; 
tv. SelectedNode. ChildNodes. Add( tn); // 把 tn 作为 当前 结 点 的 子 结 点 ; 
tv. CollapseAll(); 

tv. ExpandAl1( ); // 折 蕾 与 展开 整个 树 结构 ; 
TreeNode tn = tv. SelectedNode; // 获 取 当 前 结 点 ; 


利用 上 述 7 个 语句 ,再 结合 C# 的 控制 语句 , 即 可 编写 出 TreeView 动态 地 显示 内 容 的 
程序 。 


4.3.4 Menu 控件 导航 


1. 应 用 Menu 控件 实现 导航 

应 用 Menu 控件 实现 导航 的 方式 与 TreeView 控件 非常 相似 ,需要 为 Menu 控件 提供 数 
据 源 。 下 面 将 利用 团委 网 页 中 的 Menu 控件 演示 其 使 用 方法 。 

(1) 在 项 目 中 新 增 “Web 窗 体 ?或 内 容 页 ,命名 为 xstw. aspx。 

(2) 从 [工具 箱 ] 的 [导航 ] 栏 目下 把 Menu 控件 添加 到 页 面 的 适当 位 置 。 

(3) 从 [工具 箱 ] 的 【数据 栏目 下 把 SiteMapDataSource EE 
控件 添加 到 页 面 的 任意 位 置 ,并 利用 [属性 ] 面 板 设置 其 ID 为 和 
smsl。 其 效果 如 图 4-16 所 示 。 

(4) 单 击 Menu 控件 右上 角 的 智能 按钮 ,可 以 展开 一 个 小 菜 
单 。 利 用 此 菜单 可 以 选择 "自动 套用 格式 ,改变 控件 的 显示 形式 。 页 41。 Menw 时 人 的 交 

(5) 在 小 菜单 中 选择 smsl 作为 数据 源 。 

最 后 ,预览 此 页 面 ,观察 效果 。 

2. Menu 控件 的 属性 设置 

Menu 对 象 的 Orientation 属性 可 以 确定 菜单 的 排列 方式 ,默认 为 纵向 (Vertical) ,也 可 
以 重新 选 定 ,改变 为 横向 (Horizontal) 。 


(1.4 ASP.NET AJAX 
WW 


4.4.1 AJAX 概述 


1. 什么 是 ASP. NET AJAX 
AJAX (Asynchronous JavaScript and XML) 是 一 种 解决 Web 交互 问题 的 技术 。 众 所 
周知 , 随 着 Web 应 用 程序 的 普及 ,许多 Web 窗 体 中 包含 的 控件 和 其 他 信息 量变 得 非常 庞 
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大 。 如 果 窗 体 中 每 个 控件 对 数据 的 提交 都 要 引起 整个 页 面 的 刷新 ,必然 导致 服务 器 的 负担 
过 重 ,系统 响应 时 间 太 长 。 

为 此 ,在 Web 应 用 程序 开发 中 ,提出 了 局 部 刷新 技术 。 即 在 Web 应 用 程序 中 , 仅 对 需 
要 提交 数据 或 者 数据 发 生变 化 的 局 部 页 面 实行 刷新 。 这 种 技术 解决 了 Web 应 用 程序 中 客 
户 机 与 服务 器 的 交互 效率 问题 。 这 就 是 AJAX 技术 ,也 称 为 无 刷新 Web 页 面 。 

2. AJAX 技术 核心 内 容 

AJAX 技术 的 核心 内 容 包括 以 下 几 方 面 。 

(1) 基于 XML 技术 的 HttpRequest 对 象 , 它 能 够 支持 客户 机 与 Web 服务 器 便利 地 通 
信 , 提 升 了 传统 HTML 方式 的 HttpRequest 技术 的 性 能 。 

(2) JavaScript 代码 ,可 以 运行 在 客户 端 ,改进 数据 验证 方式 ,提升 服务 器 和 客户 机 之 间 
的 通信 效率 。 

(3) DHTML 技术 ,能够 支持 程序 动态 地 更 新 表单 。 

(4) 构造 文件 对 象 模型 DOM ,提升 文件 处 理 效率 。 

AJAX 技术 的 应 用 ,相当 于 在 客户 机 的 浏览 器 和 服务 器 的 Web 程序 之 间 增 加 了 一 个 引 
擎 (代理 )。 当 客户 端的 浏览 器 向 服务 器 发 出 请 求 时 ,必须 通过 这 个 引擎 进行 分 析 和 判定 ,只 
有 必须 刷新 的 内 容 才 提交 Web 应 用 程序 处 理 , 因 此 Web 服务 器 只 须 生 成 这 个 页 面 中 部 分 
区 域 的 内 容 , 同 时 客户 机 的 浏览 器 也 只 须 实施 局 部 区 域 的 刷新 ,而 不 是 整体 页 面 刷新 。 
AJAX 技术 的 应 用 , 极 大 地 改善 了 Web 应 用 程序 的 交互 能 力 。 


4.4.2 ASP.NET AJAX 的 服务 器 控件 


ASP.NET 提供 了 大 量 的 AJAX 控件 ,但 【工具 箱 ] 中 上 默认 AJAX 控件 共有 5 个 ,其 中 
ScriptManager 与 ScriptManagerProxy 是 一 组 ,用 于 声明 本 页 面 支 持 AJAX 技术 ; 
UpdatePanel 是 更 新 面板 ,用 于 组 织 一 个 可 独立 刷新 的 局 部 区 域 ,UpdateProgress 是 局 部 刷 
新 进度 管理 控件 ,用 于 显示 局 部 刷新 的 进度 ; Timer 控件 则 是 一 个 计时 器 控件 ,可 以 定时 引 
发 某 些 特定 的 操作 。 

1. 应 用 ScriptManager 与 ScriptManagerProxy 控件 

如 果 需 要 Web 窗 体 支持 AJAX 技术 ,就 必须 在 窗 体 中 首先 添加 一 个 ScriptManager 对 
象 ,然后 才 可 在 此 对 象 的 后 面 添加 其 他 AJAX 控件 。 因 此 ,ScriptManager 控件 是 本 窗 体 支 
持 AJAX 技术 的 标记 ,只 有 添加 过 ScriptManager 控件 的 窗 体 ,才能 使 用 AJAX 技术 ,ASP 
.NET 的 Web 服务 器 才能 启动 AJAX 引擎 ,并 向 客户 机 发 送 与 AJAX 技术 相关 的 
JavaScript 代码 。 

注意 ; 一 个 Web 窗 体 中 只 能 使 用 一 个 ScriptManager 控件 。 

如 果 在 母 版 页 中 已 经 使 用 过 ScriptManager 控件 ,那么 在 内 容 页 中 就 不 能 再 次 添加 
ScriptManager 控件 。 为 此 ,ASP.NET 提供 了 ScriptManagerProxy 控件 。ScriptManager- 
Proxy 控件 的 功能 与 ScriptManager 控件 完全 相同 ,只 是 它 只 能 放 在 ScriptManager 控件 范 
围 之 下 。 

ScriptManager 使 用 EnablePartialRendering 属性 设置 当前 窗 体 是 否 支持 局 部 刷新 。 
其 默认 值 为 true, 即 支持 局 部 刷新 。 


2. 应 用 UpdatePanel 控件 

在 一 个 已 经 布局 完毕 的 页 面 上 ,首先 向 页 面 中 插入 ScriptManager 控件 ,接着 就 可 以 向 
该 页 面 的 某 个 区 域 中 插入 UpdatePanel 控件 。 

在 页 面 中 创建 UpdatePanel 对 象 后 ,就 可 以 向 此 对 象 中 直接 插入 文本 和 其 他 的 窗 体 控 
件 了 。 向 UpdatePanel 中 插入 控件 的 办 法 与 直接 向 窗 体 中 插入 控件 的 办 法 相同 。 为 了 检测 
UpdatePanel 的 效果 ,建议 在 此 对 象 的 控件 中 包含 交互 功能 和 提交 按钮 。 

最 后 在 浏览 器 中 检查 其 效果 。 

注意 : 同一 个 页 面 中 可 以 同时 嵌入 多 个 UpdatePanel 控件 。 

UpdatePanel 的 默认 更 新 模式 (UpdateMode) 为 Always, 代 表 只 要 有 数据 回 发 到 服务 
器 ,就 会 刷新 此 UpdatePanel。 如 果 修 改 为 Conditional 模式 , 则 需要 使 用 下 列 手段 促使 
UpdatePanel 执行 局 部 刷新 。 

(1) 内 部 控件 激发 刷新 , 单 击 某 个 UpdatePanel 中 的 按钮 会 激发 它 执 行 局 部 刷新 。 

(2) 外 部 控件 激发 刷新 ,如 果 需 要 使 用 外 部 按钮 激发 UpdatePanel 的 刷新 , 则 需要 选中 
此 UpdatePanel ,在 其 [属性 】 面 板 中 针对 Triggers 元 素 进 行 设 置 ,在 ControlID 中 设置 能 够 
激发 此 UpdatePanel 刷新 的 对 象 名 称 , 如 图 4-17 所 示 。 


» ControliD jian 


Click 加 


NE EventName 
RQ UpdatePanel. A 


4-17 为 UpdatePanel 控件 设置 外 部 触发 刷新 的 控件 


3. 应 用 UpdateProgress 控件 

UpdateProgress 控件 的 作用 是 呈现 UpdatePanel 对 象 提交 数据 的 更 新 情况 。 开 发 者 可 
以 在 窗 体 中 添加 UpdateProgress 控件 ,通过 这 个 控件 的 对 象 显示 任务 的 完成 情况 。 

如 果 不 指定 UpdateProgress 对 象 监控 的 UpdatePanel 对 象 名 称 , 则 它 监控 所 有 UpdatePanel 
对 象 的 更 新 情况 ,显示 整体 进度 消息 。 和 否则 ,可 以 通过 其 属性 AssociatedUpdatePanel ID 设 
定 此 对 象 的 监控 目标 ,如 图 4-18 所 示 。 

一 个 Web 窗 体 中 可 以 添加 多 个 UpdateProgress 控件 ,此 控件 的 使 用 必须 以 导入 
ScriptManager 对 象 为 前 提 。 

4. 应 用 Timer 控件 

Timer 控件 是 一 个 按照 指定 的 时 间 间 隔 自动 启动 某 种 特定 动作 的 控件 。 在 Web 应 用 
程序 设计 中 ,Timer 的 作用 就 是 对 于 页 面 指定 刷新 的 间隔 ,保证 页 面 每 隔 一 段 时间 就 自动 执 
行 一 次 回 发 服务 器 的 操作 。 
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ScriptManager - ScriptManagerl 


平方 | 


正在 刷新 ， 请 您 稍 后 。。。。 


图 4-18 设置 UpdateProgress 控件 监控 刷新 过 程 


Timer 控件 也 属于 AJAX 控件 ,需要 ScriptManager 对 象 的 支持 。 其 关键 属性 如 表 4-1 所 示 。 
表 4-1 Timer 控件 的 属性 ,事件 与 方法 


属性 /事件 /方法 可 能 的 取 值 含 义 

Interval 数值 间隔 的 毫秒 数 ,如 果 输 入 500, 则 表示 每 0. 5 秒 激发 一 次 
Enabled true/false 可 用 性 

Trick 事件 激发 后 对 应 的 事件 


例如 ,希望 系统 每 隔 0. 1 秒 输 出 一 次 “I love You1”, 则 可 以 如 下 操作 。 
O@ 新 创建 Web 窗 体 。 

@ 向 窗 体 中 添加 ScriptManager 控件 。 

@@ 向 窗 体 中 添加 Timer 控件 ,设置 其 属性 Interval 的 值 为 100。 


@ 双击 窗 体 中 的 Timer 控件 ,系统 自动 向 此 窗 体 的 cs 文档 中 添加 函数 Timerl 
_Trick。 然 后 ,向 这 个 函数 中 输入 代码 : 


Response. Write("I love Youl ") 


@ 保存 文档 ,预览 并 检查 效果 。 
作 5 客户 端 脚本 技术 
+ 


4.5.1 客户 端 脚 本 的 概念 


传统 的 、 运 行 于 客户 端的 JavaSeript 语句 为 网 页 特效 增色 不 少 。 事实 上 ,在 动态 网 站 的 
开发 中 ,客户 端 脚本 也 可 以 大 展 其 风采 , 极 大 地 改进 程序 的 灵活 性 。 

目前 ,客户 端 脚本 的 用 途 主要 体现 在 以 下 几 个 方面 ; 改变 控件 的 属性 ; 为 控件 添加 特 
效 ; 弹出 警示 性 消息 框 ; 核实 客户 是 否 确实 想 执行 某 一 带 有 危险 性 的 操作 ; 对 表单 输入 的 
数据 进行 客户 端 验证 。 

4.5.2 客户 端 脚本 技术 在 网 站 开发 中 的 应 用 

1. 改变 控件 属性 


对 于 Web 窗 体 中 的 控件 ,VS2008 开发 工具 提供 的 属性 比较 单调 ,要 想 实现 比较 灵动 的 
效果 ,通常 需要 使 用 客户 端 脚本 技术 。 
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例如 ,当前 Web 窗 体 中 有 一 个 按钮 控件 ,控件 名 称 为 btn。 如 果 希 望 此 按钮 在 鼠标 县 
停 时 成 为 红色 的 字 , 而 且 按钮 变 得 宽大 ; 而 鼠标 离开 此 按钮 时 文字 成 为 绿色 ,而 且 宽 度 变 
小 。 则 可 以 使 用 下 面 的 代码 ,如 图 4-19 所 示 。 


1Bim protpeted void Page Load(lobject sender, Eventhres e) 


tn. Attributes. Add ("onlouseDver", "this. style. color='#ff0000', this., style. width=300"); 
tn. Attributes. 具 dd"onllouseLeaye"， "this. style. color=' 00ff00' , this. style. width=120"); 


图 4-19 改变 控件 属性 的 客户 端 JavaScript 程序 


2. 输出 警示 性 信息 

Web 窗 体 中 的 许多 操作 都 可 能 出 现 操作 失败 的 情况 。Web 窗 体 默 认 的 提示 方式 是 直 
接 输出 一 行文 字 。 如 果 能 够 以 一 个 警示 窗口 的 形式 弹出 警示 性 信息 ,无 疑 更 加 引 人 注 目 。 
基于 此 ,在 设计 Web 窗 体 的 时 候 , 对 于 需要 输出 的 警示 性 信息 ,都 可 以 采取 以 下 方式 : 


<script>alert( "警示 性 信息 的 内 容 !) ; </script> 

例如 ,在 C# 的 程序 代码 中 ,可 以 使 用 

Response. Write("< script > alert( ' 不 允许 这 样 操作 ! '); </script >"); 
或 者 

res. Text = "< script > alert( ' 不 允许 这 样 操作 !'); </script >" 


这 两 种 形式 来 输出 警示 性 信息 。 

3, 对 危险 性 动作 的 确认 

Web 窗 体 中 的 许多 操作 都 是 带 有 一 定 风险 性 的 。 为 防止 用 户 的 误 操作 导致 严重 后 果 ， 
通常 在 程序 开发 时 要 为 危险 性 动作 提供 “确认 机制。 比如 按钮 控件 btn 的 功能 是 删除 存储 
在 磁盘 上 的 某 个 文件 ,那么 在 真正 地 实施 删除 前 ,需要 在 客户 端 请 求 用 户 的 确认 。 

看 下 面 的 语句 : 

<asp:Button ID = "btn" runat = "server" onclick = "btn_Click" Text = "删除 文件 " 

onClientClick = "return confirm( ' 您 确实 需要 删除 这 个 文件 吗 ?);”/> 

在 这 个 语句 中 ,return confirm();? 就 是 一 个 JavaScript 语句 ,其 返回 值 会 根据 用 户 的 
回答 而 使 用 true 或 false。 

在 本 例 中 ,如 果 返 回 值 为 false, 系 统 就 不 向 服务 器 反馈 信息 ,将 不 执行 删除 文件 的 操 
作 。 对 于 Button 控件 来 讲 ,onClick 属性 指向 在 服务 器 端 执行 的 方法 的 名 称 ,应 该 在 相应 的 
cs 文件 中 有 对 应 的 方法 框架 及 操作 代码 。 而 onClientClick 属性 指向 需要 在 客户 端 执行 的 
JavaScript 函数 ,或 者 是 一 个 JavaScript 语句 。 


候 考 是 


1. 什么 是 网 站 的 主题 ? 主题 中 主要 包括 哪 两 类 文件 ? 
2. 与 CSS 文件 相 比 ,网 页 的 主题 文件 有 什么 作用 ? 其 操作 有 什么 特点 ? 
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3. 什么 是 母 版 页 ?在 母 版 页 中 必须 包括 什么 控件 ? 

4. 什么 是 内 容 页 ?内 容 页 中 是 否 包括 整个 页 面 的 框架 ? 内 容 页 通过 什么 方式 与 母 版 
页 连接 起 来 ? 

5. 如 何 把 Photoshop 的 页 面 布 局 与 母 版 页 联系 起 来 ? 

6. 什么 是 站 点 地 图 文件 ?这 个 文件 的 名 称 是 什么 ?是 以 什么 格式 存储 的 ? 

7. SiteMapPath 控件 的 用 途 是 什么 ? 如何 才能 使 SiteMapPath 与 站 点 地 图 文件 联 
系 起 来 ? 

8. 什么 是 TreeView 控件 ?如何 利用 站 点 地 图 和 TreeView 控件 创建 树 状 的 网 站 导航 
系统 ? 

9. 什么 是 Menu 控件 ? 如何 利用 站 点 地 图 和 Menu 控件 创建 树 状 的 网 站 导航 系统 ? 

10. 什么 是 AJAX 技术 ,有 什么 先进 性 ? 

11. 在 Web 窗 体 中 ,设置 UpdatePanel 控件 有 什么 意义 ?UpdatePanel 控件 在 Web 窗 
体 中 生效 的 前 提 条 件 是 什么 ? 

12. 什么 是 ASP.NET 程序 的 客户 端 脚本 ? 它 主要 有 哪些 用 途 ? 


仁 机 实 训 是 


启动 VS2008 ,新 建 项 目 Test4 ,为 医院 信息 管理 系统 创建 一 套 Web 应 用 程序 的 主 框 
架 。 根 据 医 院 要求 ,需要 建立 医生 查询 .医生 信息 插入 .医生 信息 修改 .医生 信息 删除 .病人 
信息 查询 .病人 信息 插入 病人 信息 修改 .病人 信息 删除 等 基础 模块 ,还 要 建立 挂号 .诊断 、 取 
药 等 常规 业务 模块 。 根 据 要 求 ,完成 以 下 任务 。 

(1) 为 此 项 目 添加 CSS 文档 ,设置 二 body 二 的 默认 样式 ,并 定义 一 级 标题 ,二 级 标题 、 
三 级 标题 的 样式 。 

(2) 要 求 以 Photoshop 布局 页 面 ,并 在 此 基础 上 为 此 项 目 创建 母 版 页 。 

(3) 根据 题目 要 求 ,设计 各 个 模块 对 应 的 Web 窗 体 文件 名 ,然后 创建 站 点 地 图 ; 要 求 站 
点 地 图 中 包括 全 部 预 设 的 页 面 ,而 且 层 次 关系 明确 、 清 晰 。 

(4) 在 母 版 页 中 添加 SiteMapPath 和 TreeView 导航 信息 。 

(5) 依据 母 版 页 创建 各 个 内 容 页 ,简单 地 输入 信息 。 

(6) 为 内 容 页 添加 ScriptManager 控件 ,并 使 用 UpdatePanel 管理 内 容 页 中 的 控件 。 通 
过 预览 页 面 ,检查 UpdatePanel 的 作用 。 
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学 习 要 点 

本 章 主要 学 习 以 VS2008 的 服务 器 资源 管理 器 实施 针对 SQL Server 数据 库 的 管理 方 
法 。 要 求 了 解 关 系数 据 库 的 概念 ,并 了 解 表 、 字 段 类 型 .主键 . 表 间 关系 的 概念 ,了 解 查询 生 
成 器 的 概念 与 使 用 。 本 章 要 求 重 点 关注 以 下 内 容 : 

。 建立 面向 具体 数据 库 的 “数据 连接 ”技术 或 者 创建 新 数据 库 的 技术 。 

。 基于 “数据 连接 ”创建 或 修改 数据 表 结 构 的 技术 。 

。 在 “数据 连接 ”基础 上 创建 查询 的 技术 。 

。 简单 SQL 语句 的 设计 。 


6.1 数据库 的 概念 


5.1.1 数据 库 的 定义 


1. 什么 是 数据 库 

所 谓 数据 库 , 是 大 量 数据 的 集合 , 指 采用 标准 化 的 结构 ,按照 一 定 的 规范 对 数据 进行 组 
织 与 管理 而 形成 的 大 规模 数据 的 集合 。 

2. 数据 库 的 主要 特点 

数据 库 是 按照 严格 的 数学 模型 建立 起 来 的 ,数据 文件 采用 统一 的 数据 结构 。 因 此 ,数据 
模型 不 仅 能 够 描述 数据 本 身 的 特点 ,而 且 能 够 描述 数据 之 间 的 联系 。 正 是 由 于 数据 库 采用 
了 规范 的 数学 模型 ,使 数据 可 以 完全 独立 于 程序 ,数据 存储 方式 与 外 部 程序 可 以 完全 独立 。 

数据 库 系统 的 概念 出 现 以 后 ,出 现 了 许多 类 型 的 数据 库 平 台 ,并 且 各 数据 库 平台 都 对 数 
据 库 的 性 能 进行 了 优化 和 扩展 ,建立 了 专门 的 数据 库 管理 系统 平台 ,实现 了 数据 定义 、 数 据 
操作 功能 ,大 型 数据 库 还 增加 数据 库 的 安全 性 、 完 整 性 、 并 发 控制 和 故障 恢复 功能 。 

数据 库 技术 的 出 现 使 信息 在 计算 机 中 的 管理 真正 地 成 为 可 能 ,使 信息 管理 的 安全 性 、 正 
确 性 得 到 了 保障 。 数 据 库 系统 出 现 以 后 ,计算 机 的 功能 就 不 再 局 限于 科学 计算 ,人 们 开始 利 
用 计算 机 存储 大 量 数据 ,用 计算 机 对 数据 库 中 的 数据 进行 检索 ,查询 ,使 人 类 走出 了 抄 纸 片 、 
翻 卡片 的 信息 处 理 时 代 , 进 入 了 以 计算 机 进行 信息 处 理 的 时 代 。 

3. 数据 库 的 类 型 

从 数据 库 的 概念 出 现 以 来 ,主要 出 现 过 以 下 几 种 类 型 的 数据 库 。 
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1) 层次 模型 

层次 模型 是 一 种 树 结构 模型 ,类 似 于 人 类 社会 中 的 血亲 关系 图 或 行政 机 构图 ,来 源 于 数 
据 结构 中 树 的 概念 。 其 主要 特点 是 : 除根 外 的 任 一 个 结 点 都 有 且 仅 有 一 个 父 结 点 ; 在 其 数 
据 操作 过 程 中 ,需要 考虑 存 取 路 径 。 

2) 网 状 模型 

网 状 模型 是 一 种 有 向 图 模型 ,类 似 于 人 类 社会 中 的 交通 网 络 ,来 源 于 数据 结构 中 图 的 概 
念 。 其 主要 特点 是 : 结 点 间 的 联系 不 受 约束 ; 在 这 种 模型 下 ,数据 操作 也 必须 考虑 存 取 路 
径 , 操 作 过 程 对 使 用 者 的 要 求 较 高 。 

3) 关系 模型 

关系 模型 是 一 种 基于 二 维 表 结构 的 模型 ,类 似 于 人 类 社会 中 常用 的 二 维 表格 。 其 主要 
特点 是 : 被 管理 的 信息 必须 被 规范 成 二 维 表 格 的 形式 ,数据 所 在 单元 格 的 位 置 表示 数据 的 
特定 含义 ,数据 操作 过 程 中 不 需要 考虑 存 取 路 径 , 是 当前 广泛 使 用 的 数据 模型 。 

4) 面向 对 象 模型 

面向 对 象 模型 是 一 种 基于 面向 对 象 程序 设计 思路 形成 的 数据 模型 ,其 主要 结合 了 关系 
模型 和 面向 对 象 程序 设计 的 优势 ,是 数据 库 技术 发 展 的 未 来 方向 。 


5.1.2 关系 数据 库 的 概念 


1. 关系 模型 的 特点 

关系 模型 以 规范 的 二 维 表 组 织 数 据 ,不 允许 表 中 套 表 。 关 系 模型 规定 : 表 中 的 一 行 是 
一 条 记录 ,用 于 描述 一 个 实体 的 各 个 属性 的 取 值 ,也 称 为 一 个 元 组 ; 表 中 一 列 为 一 个 字段 ， 
用 于 描述 实体 集 的 一 个 属性 及 其 取 值 ,也 称 为 一 个 数据 项 。 

在 关系 模型 中 ,不 允许 两 行 完 全 相同 ,即行 不 准 重复 。 由 此 可 知 ,在 一 个 关系 表 中 必然 
存在 一 个 字段 或 一 个 字段 组 合 能 够 唯一 地 确定 一 条 记录 ,这 个 标记 被 称 为 主键 (primary 
key) ,简称 为 键 (key) 。 

为 了 完整 地 描述 一 个 管理 事务 ,通常 需要 多 表 协 同 。 协 同 的 多 表 之 间 通 过 一 定 的 语义 
关系 实现 约束 。 人 们 把 若干 相关 的 数据 表 组 织 在 一 起 ,就 构成 了 关系 数据 库 (Relation 
DataBase,RDB) 。 

2. 关系 模型 的 实例 

在 一 所 大 学 中 ,学 生 的 选课 和 考核 成 绩 是 学 生 管 理 的 重要 方面 。 为 解决 这 一 问题 ,通常 
就 可 以 使 用 一 个 关系 数据 库 来 解决 。 在 这 个 关系 数据 库 中 至 少 应 该 包括 三 张 数据 表 , 如 
表 5-1 一 表 5-3 所 示 。 


表 5-1 学 生 表 
学 号 姓名 性 别 生日 院 系 专业 联系 电话 奖学金 
S001 张 萍 志 男 1989-12-01 物理 系 物理 学 687091234 1000 
S002 李 大 源 男 1990-01-12 ”教育 系 教育 史 687991234 200 
S003 刘 明 女 1990-04-12 ”物理 系 物理 学 698721212 800 
S004 崔 丽 丽 女 1991-01-01 。 教育 系 学 前 教育 。 698712345 0 
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表 5-2 课 程 表 
课程 号 课程 名 学 分 开课 单位 
K001 力学 4 物理 系 
K002 热学 | 物理 系 
K003 教育 心理 学 教育 系 
Ko04 幼儿 教育 和 教育 系 

表 5-3 成 绩 表 
学 号 课程 号 成 绩 考试 时 间 
S001 K001 98 2010-12-12 
S001 K002 82 2011-01-10 
S002 K001 97 2010-12-12 
S002 K002 85 2011-01-10 
S002 K003 81 2011-01-14 
S004 K003 74 2011-01-14 
S004 K004 92 2011-01-05 


从 前 面 的 三 张 数据 表 可 以 看 出 以 下 几 点 。 

(1) 学 生 表 保存 了 学 生 的 基本 信息 ,每 个 学 生 占 据 一 条 记录 ,在 学 校 管理 中 不 允许 两 位 
学 生 的 学 号 相同 ,因此 学 号 可 以 作为 学 生 表 的 主键 。 

(2) 课程 表 保存 了 学 校 开课 的 信息 ,开设 的 每 一 门 课 都 是 一 条 记录 ,课程 号 可 以 作为 课 
程 表 的 主键 。 

(3) 在 成 绩 表 中 ,学 号 和 课程 号 都 可 能 重复 (因为 一 个 学 生 可 以 选修 多 门 课程 ,一 门 课 
程 可 能 被 多 名 学 生 选 修 ) ,因此 单纯 的 学 号 和 课程 号 都 不 可 以 作为 主键 。 如 果 允 许 重 修 的 
话 ,只 有 “学 号 十 课程 号 十 考试 时 间 ” 才 能 唯一 地 确定 一 条 成 绩 记 录 ,因此 “学 号 十 课程 号 十 
考试 时 间 ? 可 以 作为 成 绩 表 的 主键 。 然 而 这 个 作为 主键 的 字段 组 合 过 于 复杂 ,不 便于 管理 。 
在 实际 设计 中 ,人 们 通常 为 成 绩 表 增加 一 个 自 增长 的 整 型 变量 ID ,作为 成 绩 表 的 主键 。 

(4) 从 成 绩 表 的 语义 可 知 ,成 绩 表 中 的 学 号 字段 的 取 值 必须 是 学 生 表 中 的 学 号 之 一 , 表 
示 选 课 的 学 生 是 校内 的 在 编 学 生 ; 成 绩 表 中 的 课程 号 必须 是 课程 表 中 的 课程 号 之 一 ,表示 
成 绩 单 中 的 课程 必须 是 学 校 开设 的 课程 。 也 就 是 说 成 绩 表 中 的 学 号 依赖 于 学 生 表 中 的 学 
号 ,成 绩 表 中 的 课程 号 依赖 于 课程 表 中 的 课程 号 。 这 就 是 外 键 的 概念 ,成 绩 表 中 的 学 号 和 课 
程 号 字段 是 其 他 表 的 外 键 ,它们 分 别 要 依赖 于 其 他 表 中 的 数据 。 

3. 设计 关系 数据 库 的 关键 流程 

要 设计 关系 数据 库 , 必 须 遵 循 一 定 的 流程 ,使 数据 库 达到 一 定 级 别 的 范式 ,避免 数据 元 
余 和 不 一 致 现象 。 其 基本 过 程 如 下 。 

首先 ,需要 进行 详细 的 需求 分 析 ,绘制 实体 -联系 图 ( 即 E-R 图 ) 或 者 UML 类 图 。 

其 次 ,将 E-R 图 或 UML 图 转化 为 关系 模型 , 即 转化 出 若干 个 二 维 表 的 形式 。 

第 三 ,明确 每 张 二 维 表 的 主键 和 外 键 ,明确 二 维 表 之 间 的 约束 关系 。 

第 四 ,分 析 二 维 表 的 每 一 列 的 数据 类 型 ,明确 每 一 列 的 存储 宽度 。 

第 五 ,形成 完整 的 关系 数据 库 设计 方案 ( 见 表 5-4 一 表 5-6)。 
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最 后 ,选择 一 套数 据 库 管理 系统 ,创建 数据 库 和 数据 表 , 输 入 少量 的 数据 。 
表 5-4 学 生 表 的 基本 结构 


字段 名 称 字段 类 型 字段 宽度 说 明 备注 
xh nchar 10 学 生 的 学 号 主键 
xm nchar 12 学 生 的 姓名 不 能 为 空 
xb nchar 1 学 生 的 性 别 不 能 为 空 
csdate datetime 学 生 的 出 生日 期 
dwei nchar 8 学 生 所 在 院 系 
zhye nchar 10 学 生 的 学 习 专业 
phone nchar 13 联系 电话 
jlje int 获得 奖学金 的 金额 量 


表 5-5 课程 表 的 基本 结构 


字段 名 称 字段 类 型 字段 宽度 说 明 备注 
kch nchar 6 课程 编号 主键 
kcm nchar 12 课程 名 称 不 能 为 空 
xuefen int 课程 的 学 分 不 能 为 空 
kkdw nchar 12 开课 单位 不 能 为 空 


表 5-6 成 绩 表 的 基本 结构 


字段 名 称 字段 类 型 字段 宽度 说 明 备注 
ID int 自 增 序号 主键 
xh nchar 10 学 生 的 学 号 外 键 
kch nchar 6 课程 的 编号 外 键 
Score float 
kstime datetime 本 课程 的 考试 日 期 


5.1.3 数据 库 系统 
1. 数据 库 系统 的 基本 概念 


人 们 建构 数据 库 系 统 的 目标 在 于 存储 和 提取 所 需要 的 信息 , 它 包括 数据 管理 所 涉及 的 


各 个 方面 。 从 数据 库 系 统 的 内 容 看 ,包括 了 数据 ,用 户 、 硬 件 和 软件 四 个 部 分 。 


数据 库 系统 的 特点 为 : 采用 结构 化 的 数据 模型 ,有 和 较 强 的 数据 共享 能 力 ; @ 较 高 的 


数据 独立 性 ; @ 数 据 的 完整 一 致 性 ; @ 最 小 的 元 余 度 ; @ 数 据 安全 ,保护 性 。 
在 数据 库 系 统 的 软件 体系 中 ,主要 包括 操作 系统 、 数 据 库 管理 系统 和 数据 库 应 月 


有 系统 三 


个 部 分 。 其 中 数据 库 管理 系统 (DataBase Management System, DBMS) 是 对 数据 库 进行 管 
理 的 系统 软件 , 它 是 用 户 和 数据 库 之 间 的 接口 ,为 用 户 提供 对 数据 库 进行 操作 的 各 种 命令 。 
人 们 通常 所 说 的 FoxPro、Access、Oracle、SQL Server、Sybase 等 系统 软件 包 本 身 均 为 数据 
库 管理 系统 。 数 据 库 管理 系统 的 功能 包括 数据 定义 (DDL) ,数据 操作 (DML) ,数据 控制 ( 安 


全 性 ,完整 性 ,数据 库 恢复 、 并 发 控制 ) 和 数据 库 维护 等 功能 。 


人 们 为 某 种 应 用 需求 而 在 DBMS 基础 上 开发 的 各 种 信息 系统 、 动 态 网 站 都 是 数据 库 技 
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术 与 其 他 开发 工具 结合 的 产物 ,属于 数据 库 应 用 系统 的 范畴 。 

2. 主流 的 数据 库 管理 系统 

DBMS 对 动态 网 站 的 建设 和 性 能 有 决定 性 影响 。 目 前 ,主流 的 DBMS 都 是 关系 数据 库 
管理 系统 (RDBMS) 。 

应 用 于 信息 系统 中 的 DBMS 主要 分 为 以 下 两 类 。 

(1) 桌面 DBMS。 比 较 著 名 的 有 Visual FoxPro 和 Access 系统 。 

(2) 网 络 DBMS 系统 。 比 较 著 名 的 有 Microsoft SQL Server、Oracle、MySQL 和 
Sybase。 

从 动态 网 站 开发 技术 看 ,各 类 DBMS 都 具有 很 强 的 适应 性 和 接口 ,都 能 够 适应 主流 的 
几 种 开发 技术 。 但 在 具体 的 实践 中 ,又 形成 了 一 些 习 惯性 的 搭配 模式 ,常见 的 有 Access 十 
ASP 模式 .SQL Server 十 ASP 模式 .SQL Server 十 ASP .NET 模式 .MySQL 十 PHP 模式 、 
Oracle 十 JSP 模式 和 SQL Server 十 JSP 模式 等 。 

本 书 将 以 SQL Server 数据 库 为 例 讲 述 数据 库 管理 系统 的 使 用 方法 。 


6.2 SQL Server 2005 与 VS2008 


5.2.1 SQL Server 2005 系统 简介 


1. SQL Server 起 源 与 发 展 

SQL Server 数据 库 管理 系统 是 Microsoft 的 产品 ,是 一 个 面向 网 络 的 中 大 型 数据 库 管理 系 
统 。SQL Server 已 经 发 布 过 多 个 版 本 ,在 国内 应 用 比较 广泛 的 版 本 有 SQL Server 6. 5、 
SQL Server 2000、SQL Server 2005 ,目前 的 最 新 版 本 是 SQL Server 2008 。 

作为 著名 的 RDBMS,SQL Server 全 面 支持 标准 的 数据 库 操作 语言 SQL ,而 且 为 提升 
数据 库 的 并 发 处 理 能 力 , SQL Server 对 标准 SQL 进行 了 扩展 ,形成 了 具有 自身 特色 的 
Transct-SQL 体系 。 

2. SQL Server 2005 主要 特色 

SQL Server 2005 是 发 布 于 2005 年 前 后 ,一 个 具有 重要 影响 的 版 本 。 为 支持 不 同 层次 
的 需求 ,SQL Server 2005 推出 了 多 个 子 版 本 ,其 中 企业 版 只 能 安装 在 服务 器 版 的 操作 系统 
上 ,开发 版 则 可 以 安装 在 包括 Windows XP SP2 以 上 版 本 的 各 种 Windows 操作 系统 上 , 另 
外 还 有 标准 版 工作 组 版 等 不 同 的 版 本 。 目 前 ,SQL Server 2005 已 形成 了 一 个 非常 庞大 的 
体系 ,除了 必需 的 SQL Server Service 客户 端 操 作 程 序 外 ,还 提供 了 对 Visual Studio .NET 
的 支持 、 商 业 智能 分 析 等 功能 。 

3. SQL Server 2005 的 主要 组 件 

完整 的 SQL Server 2005 除了 提供 非常 强大 的 数据 处 理 能 力 外 ,还 提供 了 各 种 组 件 ,以 
帮助 用 户 完成 针对 服务 器 的 配置 与 管理 。 

1) 服务 器 端 组 件 

SQL Server 2005 的 服务 器 端 组 件 有 以 下 几 个 。 

(1) SQL Server 数据 库 引擎 用 于 进行 数据 库 建 设 、 管 理 和 保护 数据 等 核心 服务 ,能够 
复制 ,全 文 搜索 以 及 管理 关系 数据 。 
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(2) Analysis Services 包括 用 于 创建 和 管理 联机 分 析 处 理 以 及 数据 挖掘 应 用 程序 等 
本。 


站 


(3) Report Services 用 于 各 类 报表 ,是 一 个 可 用 于 开发 报表 应 用 程序 的 可 扩展 平台 。 
(4) Integration Services 是 一 组 图 形 工具 和 可 编程 对 象 ,用 于 移动 复制 和 转换 数据 。 
2) 客户 端 组 件 
SQL Server 2005 的 客户 端 组 件 有 以 下 几 个 。 
(1) Management Studio 是 一 个 集成 操作 环境 ,对 数据 库 的 所 有 直接 操作 都 可 以 在 这 
里 完成 。 
(2) Analysis Services 部 署 向 导 为 商业 智能 应 用 程序 提供 了 联机 分 析 处 理 和 数据 挖掘 
功能 ,能 够 实现 跨 多 个 应 用 系统 的 联机 分 析 。 

(3) SQL Server Business Intelligence Development Studio 是 一 个 集成 的 开发 环境 , 主 
要 用 于 开发 商业 智能 构造 , 它 包括 一 些 项 目 模板 ,能 够 为 开发 特定 的 构造 提供 模板 支持 。 

SQL Server 的 客户 端 还 提供 了 很 多 配置 工具 ,其 中 比较 重要 的 是 SQL Server 
Configuration Manager, 它 能 够 为 SQL Server 服务 .SQL Server 服务 的 网 络 连接 协议 、 客 
户 端 协议 .客户 端 别名 管理 等 提供 基本 的 配置 管理 工具 。 

总 之 ,SQL Server 2005 的 各 种 组 件 为 开发 者 提供 了 一 个 便捷 、 强 大 的 可 视 化 界面 , 保 
证 开发 者 可 以 利用 SQL Server 2005 实现 所 需 的 操作 。 


5.2.2 VS2008 的 SQL Server 2005 模块 


作为 一 款 功能 强大 的 开发 工具 ,VS2008 中 内 置 了 一 套 精 简 版 的 SQL Server 2005 系 
统 。 即 当 开发 者 安装 VS2008 时 ,系统 会 自动 地 把 SQL Server 2005 Express 和 C#、VB 等 
开发 工具 一 起 安装 到 开发 者 的 计算 机 中 。 

VS2008 内 置 的 SQL Server 2005 属于 精简 版 本 ,对 数据 库 的 各 种 操作 可 以 通过 
VS2008 提供 的 服务 器 资源 管理 器 实现 。 

需要 指出 的 是 ,由 于 VS2008 内 置 的 SQL Server 2005 Express 是 精简 版 本 , SQL 
Server 2005 体系 的 多 数 可 视 化 工作 站 组 件 都 没有 安装 。 所 以 ,对 已 经 习惯 使 用 SQL Server 
2005 各 种 可 视 化 组 件 的 开发 者 来 讲 , 可 能 还 需要 补充 安装 SQL Server 2005 的 工作 站 组 件 。 

如 果 已 安装 VS2008 的 用 户 确实 需要 补充 安装 这 些 组 件 , 则 需要 首先 通过 【控制 面板 】 
- 卸 添 加 与 删除 程序 启动 印 载 Microsoft SQL Server 2005 的 程序 ,在 新 启动 的 【SQL 
Server 2005 的 配置 】 对 话 框 中 选择 删除 [SQL Server 2005 公共 组 件 】 中 的 【工作 站 组 件 】。 
当 VS2008 内 置 的 工作 站 组 件 被 删除 后 ,就 可 以 利用 SQL Server 2005 安装 盘 补充 安装 全 部 
的 工作 站 组 件 了 。 或 者 直接 利用 Microsoft 提供 的 SQL Server 2005_SSMSEE. MSI 安装 
一 份 精简 版 的 组 件 Management Studio Express。 


5.2.3 VS2008 的 服务 器 资源 管理 器 


正如 前 面 指 出 的 ,如 果 正 确 地 安装 了 VS2008, 则 已 经 在 计算 机 中 安装 了 一 套 SQL 
Server 2005/2008 数据 库 管理 系统 。 通 过 VS2008 自 带 的 服务 器 资源 管理 器 就 能 够 完成 大 
部 分 的 数据 库 操作 。 
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1. VS2008 服务 器 资源 管理 器 简介 
启动 VS2008, 利 用 菜单 [视图 】->【 服 务 器 资源 管理 器 ] 即 可 在 VS2008 应 用 窗口 左 侧 打 
开 [ 服 务 器 资源 管理 器 ] 面 板 ,如 图 5-1 所 示 。 
文件 日 对 各 日 视 四 W 工具 四” 到 KG 富 口 W) 帮 动 由 
PS PT 品 
Xx 


国 2S 和 a 

ET 
由 加 MAXLPC 

9 昌国 辐 


-madpe\sqlexpress Ma.dbo 


图 5-1 VS2008 的 服务 器 资源 管理 器 操作 界面 


从 图 5-1 可 知 ,本 地 服务 器 的 名 称 为 MAXLPC, 可 单 击 服务 器 名 称 前 面 的 十 ,展开 此 服 
务 器 。 如 果 右 击 数据 连接 项 , 则 弹出 一 个 快捷 菜单 ,从 中 可 以 选择 【新 建 连接 3 或 者 [创建 新 
SQL Server 数据 库 】。 

2. 连接 到 已 知 的 SQL Server 数据 库 

如 果 已 经 在 SQL Server 中 创建 数据 库 ,而且 知道 这 个 数据 库 名 称 , 则 可 以 针对 此 数据 
库 创建 一 个 【数据 连接 】。 然 后 ,就 可 以 利用 此 连接 打开 数据 库 中 的 某 一 数据 表 , 进 而 操作 这 
个 数据 表 。 

假设 已 知 SQL Server 2005 的 数据 库 名 称 为 TTT, 现 在 需要 在 VS2008 的 服务 器 资源 
管理 器 中 创建 连接 到 数据 库 TTT 的 [数据 连接 ]。 其 操作 过 程 为 ; 

首先 ,打开 [服务 器 资源 管理 器 面板 , 右 击 【数据 连接 】, 则 弹出 一 个 快捷 菜单 ,从 中 选择 
【新 建 连接 】, 则 打开 一 个 【添加 连接 ] 对 话 框 ,如 图 5-2 所 示 。 

在 【数据 源 ] 文 本 框 中 选择 “Microsoft SQL Server(SqlClient)”, 在 【服务 器 名 下拉 列表 
框 中 输入 “. \sqlexpress”, 然 后 选择 【使 用 Windows 身份 验证 了 单 选 按钮 。 这 些 配置 的 含义 
是 : 利用 SQL Server 的 客户 端 程序 访问 本 地 的 SQL Server 数据 库 ,访问 时 使 用 Windows 
内 置 的 身份 验证 方式 。 其 中 的 “. \sqlexpress” 代 表 本 地 计算 机 上 的 sqlexpress 服务 器 。 

先 选 中 [选择 或 输入 一 个 数据 库 名 有 单 选 按 钮 ,然后 从 其 列表 框 中 选择 数据 库 “ttt”"。 接 
着 单 击 左下 角 的 【测试 连接 按钮。 如果 测试 连接 成 功 ,只 需 单 击 【 确 定 】 按 钮 就 建立 了 一 个 
针对 数据 库 ttt 连接 。 

如 果 已 经 有 一 个 数据 库 文件 存储 在 本 地 ,但 没有 与 本 机 的 SQL Server 2005 发 生 关 联 ， 
则 可 以 先 选 中 [附加 一 个 数据 库 文件 ] 单 选 按 钮 ,然后 利用 [浏览 ] 功 能 选中 这 个 数据 库 文件 ， 
最 后 单 击 【确定 按钮 确认 操作 , 即 可 建立 针对 此 数据 库 文件 的 连接 。 

3. 新 建 SOL Server 数据 库 

在 服务 器 资源 管理 器 中 , 右 击 【数据 连接 ] 项 , 则 弹出 一 个 快捷 菜单 ,从 中 选择 [创建 新 
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SQL Server 数据 库 】, 则 打开 【创建 新 的 SQL Server 数据 库 ] 对 话 框 ,如 图 5-3 所 示 。 


输入 信息 以 连接 到 计 定 的 数据 源 , 或 单 去 “更 改 ” 运 泽 号 一 个 数 二 源 和 /或 提供 
程序 . 


数据 源 GG); 

Microsoft SQL Server (SqiClient) (QO. | 
服务 器 名 (E): 

Msqlexpress -| RW 
登录 到 服务 器 


加 使用 Windows 身份 验 汪 W 


司 使 用 SQL Server 身份 验证 [O) 
SR | 
| 9 医 一 
连接 到 个 数据 认 | 
一 RS 
加 日 全 用 SQL Server 身份 闪 (Q) 
队 了 0 一 个 数 宇 放 文件 PS): ] 
= HO: ] 
保存 宫 码 (9 
高 级 
[asao |] Cw | w | 
图 5-2 在 [服务 器 资源 管理 器 ] 中 添加 数据 连接 图 5-3 ”在 【服务 器 资源 管理 器 ] 中 新 建 数据 库 


在 【服务 器 名 ] 的 组 合 框 中 输入 “. \sqlexpress”, 表 示 创 建 数据 库 的 服务 器 是 本 地 计算 机 
上 的 sqlexpress 服务 器 ,选择 [使 用 Windows 身份 验证 方式 ,在 【新 数据 库 名称 】 文 本 框 中 
输入 数据 库 名 “XSGL”, 最 后 单 击 [ 确 定 ] 按 钮 。 

VS2008 会 自动 在 用 户 的 计算 机 上 创建 名 称 为 XSGL 的 数据 库 , 并 建立 针对 此 数据 库 
的 新 连接 。 

注意 ; 此 数据 库 会 自动 创建 两 个 文件 xsgl. mdf 和 xsgl_log. ldf, 前 者 存储 数据 信息 ,后 
者 存储 数据 库 的 日 志 信息 。 这 两 个 文件 默认 存储 在 SQL Server 程序 文件 夹 的 SQL1. 1\ 
MSSQL\DATA 文件 夹 内 。 例 如 ,笔者 的 SQL Server 2005 安装 在 下 盘 的 Program Files 文 
件 夹 中 ,那么 这 两 个 文件 就 存储 在 下 :\Program Files\Microsoft SQL Server\SQL1. 1\ 
MSSQL\DATA 中 。 


5.2.4 以 VS2008 管理 数据 库 


在 【服务 器 资源 管理 器 面板 中 , 单 击 连接 名 称 左 侧 的 十 展开 连接 。 此 时 系统 连接 目标 
数据 库 ,为 用 户 提供 操作 界面 ,如 图 5-4 所 示 。 

1. 新 建 数据 表 及 其 表 结 构 

在 数据 库 已 连接 状态 下 ,展开 此 连接 树 状 结构 图 , 右 击 【 表 】, 从 其 快捷 菜单 中 选择 [添加 
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图 5-4 【服务 器 资源 管理 器 ] 中 的 数据 连接 树 状 图 


新 表 】, 则 在 主 工作 区 中 出 现 新 建 表 结构 的 界面 ,如 图 5-5 所 示 。 


图 5-5 利用 [服务 器 资源 管理 器 ] 创 建 数 据 表 


按照 表 5-1 对 关系 模式 和 “学 生 表 ”结构 的 设计 ,依次 输入 每 一 字段 的 字段 名 称 \ 数 据 类 
型 .是 否 允 许 为 空 值 等 属性 。 如 图 5-6 所 示 , 输 入 xh、nchar(10), “允许 为 Null* 设 置 为 非 选 
中 状态 。 

最 后 ,在 所 有 字段 输入 完毕 后 , 单 击 工具 栏 的 [保存 ] 按 钮 ,把 表 结 构 定 义 保存 到 数据 
库 中 。 

对 于 成 绩 表 中 的 ID 字段 ,由 于 定义 为 自 增 编 号 ,需要 进行 特殊 的 设置 : 打开 “成 绩 表 ” 
的 表 定 义 , 在 输入 所 有 字段 后 ,通过 单 击 选 定 ID 字段 ,设置 其 数据 类 型 为 “int”, 然 后 再 对 底 
部 的 [ 列 属性 ] 面 板 中 的 [标识 规范 】 属 性 修改 为 “是 ”.【 标 识 增 量 ] 值 修正 为 1,【 标 识 种 子 ] 的 
起 始 值 设 为 1。 通 过 这 一 方法 ,把 ID 设置 为 自 增 量 类 型 的 数据 ,如 图 5-6 所 示 。 
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文件 四 ”篇 入 视图 V) 笋 氟 季 。 表 设 计 台 工具 0 草 XS) 窗口 W) 帮助 (H) 


-由 - 马 | 
dbo 成 绩 表 - 表 (maxipc\sqlexpress.XSGD* TX” 
到 RE 允许 Null 
ET wD int 日 
田 - 加 MAXLPC 二 neharl10) 日 
re keh nchar(G) 目 
自 节 madpesqk 
外 区 madpeisql 
生 国 madpevsql cass 
外 国 国外 昌 
导 国 表 RowGuid 否 “ 
昌国 日 rE 县 [0 
区 Es a ES 
由 国 学 下 标 闪 最 1 
让 回 视 加 FR 1 二 wo 
自 - 国 存储 过 得 不 用 于 复制 理 人 成- 
由 国 酌 -~ 小 4 -gm 
‘ ; 
(是 标 内 
ET 
就 者 


5-6 ”利用 [服务 器 资源 管理 器 ] 设 置 主键 和 自 增 字段 


注意 ; 在 数据 表 创 建 完毕 ,如 果 突 然 发 现 数据 表 结 构 不 符合 要 求 ,可 以 在 数据 连接 的 树 
状 结构 中 找到 相应 的 表 , 右 击 后 选择 [打开 表 定义 】, 即 可 在 主 工作 区 中 显示 出 数据 表 的 结构 
编辑 模式 ,可 继续 修改 表 结 构 信 息 。 

2. 设置 数据 表 字 段 的 约束 

对 数据 表 来 讲 ,除了 要 设置 包含 哪些 字段 .字段 的 数据 类 型 等 要 素 外 ,通常 还 需要 说 明 
每 个 表 的 主键 .针对 个 别 字段 的 约束 .设置 表 间 关系 等 操作 。 下 面 针 对 已 经 创建 的 “学 生 
表 ”“ 课 程 表 ”和 “成 绩 表 ” 设 置 必要 的 约束 。 

1) 设置 学 生 表 的 主键 

打开 “学 生 表 ” 的 表 定义 , 右 击 列 名 称 *xh”, 在 弹出 的 快捷 菜单 中 选择 [设置 主键 】, 于 是 
在 列 “xh” 前 面 出 现 一 个 黄色 的 小 钥匙 ,表示 设置 主键 成 功 。 

2) 限定 不 允许 空 值 的 字段 

对 于 “学 生 表 ” 中 的 姓名 字段 ,应 该 不 允许 空 值 , 即 不 允许 姓名 中 不 输入 数据 , 则 在 学 生 
表 的 表 定 义 状态 下 ,设置 “xm” 列 的 “允许 为 Null” 设 置 为 非 选 中 状态 。 

3) 设置 字段 的 Check 约束 

对 于 数据 表 中 的 某 些 字段 ,为 保证 数据 的 完整 性 ,可 能 需要 添加 特定 的 约束 ,比如 奖 学 
金 不 能 低 于 0 元 ,性 别 只 能 输入 * 男 ?或 “ 女 ”。 对 这 种 情况 应 该 使 用 Check 约束 。 即 在 “学 生 
表 ” 的 表 定 义 状态 下 , 右 击 任意 字段 ,在 弹出 的 菜单 中 选择 “Check” 约 束 ,从 左 侧 单 击 “ 添 
加 ”, 在 右 侧 “ 编 辑 Check 属性 ?栏目 的 “表达 式 ? 项 中 输入 约束 式 “xb= ' 男 ' or xb= ' 女 '”, 接 
着 再 选择 “添加 ”, 输 入 约束 表达 式 “jljie 之 =0”。 

注意 : 在 约束 表达 式 中 ,字符 串 常量 要 用 单 引 号 括 起 来 ,不 能 使 用 双 引 号 。 例 如 表达 式 
中 的 男 或 女 就 用 单 引 号 括 了 起 来 。 

3. 设置 表 间 关系 

因为 “成 绩 表 ”依赖 于 “学 生 表 ”和 “课程 表 ”, 因 此 需要 在 “成 绩 表 ”的 表 定 义 中 设置 成 绩 
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表 对 学 生 表 和 课程 表 的 依赖 关系 。 
打开 “成 绩 表 ” 的 表 定 义 , 右 击 任意 一 个 字段 名 ,在 弹出 的 快捷 菜单 中 选择 [关系 】, 则 打 
开创 建 表 间 【外 键 关系 】 对 话 框 ,如 图 5-7 所 示 。 


选 定 的 关系 (S)}: 
了 成 项 表 成 绩 表 * 


aa Eee 


图 5-7 利用 [服务 器 资源 管理 器 ] 设 置 表 间 关系 


单 击 左 下 角 的 【添加 按钮 ,添加 新 的 关系 ,然后 在 右 侧 窗口 的 [ 表 和 列 规范 ] 栏 目 右 端 的 
小 按钮 回 上 单 击 ,打开 有 具体 的 设计 对 话 框 ,如 图 5-8 所 示 。 


5-8 设置 表 间 关 系 的 对 话 框 


设置 主键 表 和 外 键 表 , 并 设置 二 表 之 间 的 对 应 关系 : 成 绩 表 的 学 号 (xh) 依 赖 于 学 生 表 
的 主键 学 号 (xh) 。 最 后 单 击 【确定 了 按钮 确认 这 一 设置 。 

同 理 ,添加 成 绩 表 的 课程 号 (kch) 对 课程 表 中 课程 号 (kch) 的 依赖 。 

注意 : 如 果 在 设置 约束 关系 前 数据 表 中 已 经 有 了 一 些 记 录 , 当 这 些 记录 不 满足 约束 关 
系 时 ,可 能 导致 约束 关系 的 设置 失败 。 需 要 先 对 这 些 记 录 进 行 适当 的 处 理 , 然 后 再 设置 约束 

4. 输入 记录 与 显示 记录 内 容 

数据 表 的 定义 工作 完成 后 ,就 可 以 向 数据 表 中 输入 数据 了 。 

展开 [数据 连接 ] 的 树 状 结构 , 右 击 需要 输入 数据 的 数据 表 名 称 ,然后 选择 [显示 表 数 据 】， 
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即 可 在 主 工作 区 中 以 二 维 表 形 式 打开 此 数据 表 , 可 以 直观 地 向 表 中 输入 数据 ,如 图 5-9 所 示 。 


图 5-9 ”以 [服务 器 资源 管理 器 ] 向 学 生 表 输入 数据 


注意 : 在 数据 输入 过 程 中 ,不 仅 要 注意 输入 的 数据 必须 满足 约束 条 件 ,而 且 还 应 注意 给 
入 数据 的 顺序 关系 。 例 如 ,在 为 学 生 表 、 课 程 表 和 成 绩 表 输入 数据 的 过 程 中 ,一 定 要 注意 先 
为 学 生 表 和 课程 表 输入 数据 ,再 为 成 绩 表 输入 数据 ; 而 且 要 保证 成 绩 表 中 的 学 号 依赖 于 学 
生 表 中 的 学 号 ,成 绩 表 的 课程 号 依赖 于 课程 表 中 的 课程 号 。 


5.2.5 SOL Server 的 查询 生成 器 


查询 是 数据 库 操 作 的 核心 。 人 们 对 数据 库 的 操作 不 能 仅 局 限于 数据 库 管 理 员 (DBA) 
通过 开发 工具 操作 数据 库 , 更 多 的 是 借助 高 级 语言 通过 查询 语句 实现 对 数据 库 的 远程 操作 。 

1. 新 建 查询 

展开 【数据 连接 了 的 树 状 结构 , 右 击 [ 表 】, 从 其 快捷 菜单 中 选择 [新建 查 询 】, 则 进入 新 建 
查询 (查询 生成 器 ) 的 状态 。 系 统 首先 弹出 一 个 【添加 表 】 对 话 框 ,等 待 开发 者 选择 查询 所 涉 
及 的 表 。 

2. 单 表 信息 查询 

如 果 所 需 的 信息 及 查询 条 件 都 来 自 一 张 数 据 表 , 则 称 为 单 表 查 询 。 例 如 ,要 查询 物理 系 
女生 的 姓名 和 奖学金 情况 , 则 只 需 把 “学 生 表 ”添加 到 查询 生成 器 中 。 如 图 5-10 所 示 ,“ 学 
生 表 ” 已 经 被 添加 到 查询 中 。 

在 中 下 部 的 区 域 中 选择 列 “xm”、“jlje”“dwei”、“xb” 等 ,并 是 设置 “xm”、“jlje” 行 的 复 选 
框 [输出 为 有 效 , 表 示 要 显示 出 这 两 列 的 信息 。 设置“dwei”“xb” 行 的 [输出 ] 复 选 框 为 无 
效 ,表示 这 两 行 作为 查询 条 件 ,不 需要 输出 ,在 这 两 行 的 [筛选 器 】 中 对 应 输入 文字 “物理 系 ” 
和 “ 女 ”, 系 统 自 动 转化 为 “N' 物 理 系 ”和 “N' 女 '”。 

此 时 可 以 在 查询 生成 器 的 底部 看 到 如 下 语句 ,这 个 语句 就 是 著名 的 SQL 语句 。 


SELECT xm，jlje FROM 学 生 表 WHERE (dwei = N' 物 理 系 ') AND (xb= N' 女 ') 
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文昌” 因 日 ”视力 革 册 寺 i 才 (RQ) 工 具 D 冯 RS) 语 DOW) 帮助 
i 了 .0D 


学 生 表 
|WHERE (dwei = N 物 理 系 ] AND (xb = N 女 ] 


Rl rim@ 


图 5-10 在 【服务 器 资源 管理 器 ] 中 创建 查询 


单 击 工 具 栏 中 的 [执行 查询 3 按钮 (如 图 5-11 所 示 ) ,可 以 看 到 此 查询 的 执行 结果 。 


3. 分 组 查询 

在 数据 查询 中 ,经 常 发 生 “ 需 要 对 数据 进行 分 组 ,然后 按照 分 组 实施 数据 统计 ”的 情形 。 
例如 ,分 单位 计算 学 生 们 获得 奖学金 的 总 额 就 是 一 个 分 组 查询 ,其 含义 是 首先 按照 单位 对 所 
有 的 学 生 实施 分 组 ,然后 计算 出 每 个 分 组 中 的 全 体 学 生 获得 奖学金 的 总 额 。 

要 实现 分 组 查询 ,需要 在 已 经 进入 到 “新 建 查询 ”的 状态 下 ,选择 菜单 【查询 生成 器 】~>~ 
【添加 分 组 依据 】, 使 查询 生成 器 的 界面 中 包括 【分 组 依据 ] 栏 目 ,然后 进行 如 图 5-12 所 示 的 
设置 。 

从 图 5-12 中 可 以 看 出 ,字段 dwei 是 分 组 依据 (Group by) ,字段 jije 是 Sum( 即 求 和 ) 。 
因此 本 查询 实现 的 功能 是 针对 学 生 表 按照 
单位 进行 分 组 ,然后 按照 分 组 对 奖学金 进行 [Pemavipolopresxseu8] 了“X| 


求 和 操作 ,计算 出 每 个 单位 的 奖学金 总 额 。 Ee 了 | 加 
查询 生成 器 底部 显示 出 了 实现 此 功能 ae 
v Dzhye 1 = 
的 SQL 语句 。 1 加 


4. 连接 查询 dre | Cr 
1 基本 思路 过， = 
在 数据 查询 中 ,如 果 查 询 条 件 或 者 输出 “| 县 oe 人 6 oii/5 3 
字段 来 自 不 同 的 数据 表 , 则 应 该 利用 连接 查 | eemres 
询 。 即 首先 要 求 两 个 或 多 个 数据 表 依据 关 
键 字段 建立 连接 ,形成 一 个 综合 多 表 字 段 的 ”图 5-12 利用 [服务 器 资源 管理 器 ] 设 置 分 组 查询 


Mill jl iiPl 国 | 
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虚 表 ,然后 在 连接 结果 的 基础 上 实施 数据 筛选 工作 。 

2) 连接 查询 示例 

要 查询 学 生 李 大 源 的 单位 性 别 以 及 他 选修 的 课程 的 课程 名 ,考试 成 绩 。 这 就 是 一 个 典 
型 的 连接 查询 ,因为 查询 结果 需要 由 三 张 数 据 表 提供 。 

首先 ,新 建 查 询 , 在 【添加 表 】 对 话 框 下 把 学 生 表 、 成 绩 表 和 课程 表 三 张 数据 表 添 加 到 查 
询 生成 器 中 。 由 于 这 三 张 表 之 间 曾 经 建立 过 表 间 关系 ,因此 添加 到 查询 生成 器 中 的 三 张 表 
会 自动 地 连接 起 来 ,如 图 5-13 所 示 。 

在 查询 生成 器 的 中 部 区 域 选 择 列 名 (字段 名 ) ,并 设 定 姓名 筛选 器 的 值 为 李 大 源 ”。 此 
时 可 从 查询 生成 器 的 底部 看 到 对 应 的 SQL 语句 。 

5. 更 新 查询 

1) 基本 思路 

除了 普通 的 查询 语句 外 ,SQL Server 系统 把 对 记录 的 修改 也 叫做 查询 : 向 数据 表 中 插 
入 记录 称 为 “插入 查询 ”, 删 除数 据 表 中 的 特定 记录 称 为 “删除 查询 ”, 修 改 指定 记录 的 内 容 称 
为 “修改 查询 ”。 

要 在 查询 生成 器 中 建立 更 新 查询 ,必须 在 【查询 生成 器 ] 状 态 下 选择 系统 菜单 【查询 生成 
器 】>【 更 改 类 型 】, 然 后 把 查询 生成 器 更 新 为 所 需 的 类 型 ,就 可 以 在 可 视 化 界面 下 直接 实现 
更 新 查询 了 。 

2) 更 新 查询 示例 

实现 记录 插入 的 查询 就 是 在 如 图 5-14 所 示 的 【查询 生成 器 ] 界 面 中 ,直接 在 它 中 部 的 区 
域 选择 字段 名 并 输入 对 应 的 数据 。 最 后 ,SQL Server 系统 会 自动 在 【查询 生成 器 ] 底 部 生成 
具有 插入 功能 的 SQL 语句 。 


出 pm 
|SELECT 学 生 表 wm, 学 生 表 .xb, 学生 表 .dwei 课程 条.kcm, 成 续 表 .score 
FROM 。 成 寻 秦 INNER JOIN IINSERT INTO 学 生 表 
课程 表 ON 成 师表 .kch = 课程 表 kch INNER JOIN 
学 生 表 ON 成 结 表 xh = 学 生 奏 沾 


hm 
ALUES 【N'S008, N 马 天 国 ] 


图 5-13 ”以 [服务 器 资源 管理 器 】 创 建 多 表 连 接 查询 图 5-14 ”以 [服务 器 资源 管理 器 3 创建 插入 查询 
(5.3 SQL 语言 简介 


5.3.1 什么 是 SQL 语言 


SQL 的 英文 全 称 为 Structured Query Language, 其 含义 是 结构 化 查询 语言 ,是 一 种 被 
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广泛 应 用 在 数据 库 管理 中 的 语言 。 由 于 SQL 语言 使 用 方便 ,简单 易 懂 , 功 能 丰富 ,很 快 在 各 
种 关系 数据 库 中 广泛 应 用 。 
虽然 SQL 名 为 查询 语言 ,但 实际 上 具有 定义 、 查 询 、 更 新 和 控制 等 多 种 功能 ,已 经 发 展 
成 为 一 种 功能 齐全 的 数据 库 操作 语言 ,现在 已 经 成 为 关系 数据 库 操作 语言 的 事实 标准 。 
目前 的 各 种 关系 数据 库 都 兼容 标准 SQL 语言 ,但 是 为 了 增强 自己 的 操作 功能 ,各 种 关 
系数 据 库 都 在 标准 SQL 语言 的 基础 上 对 SQL 语言 进行 了 扩充 ,例如 SQL Server 使 用 的 数 
据 库 操作 语言 就 是 一 种 扩充 了 的 SQL 语言 ,被 称 为 Transact-SQL 语言 ,简称 T-SQL 语言 。 


5.3.2 SOQL 单 表 查询 语句 格式 


1. SQL 的 单 表 查 询 语句 的 格式 

SQL 的 普通 查询 语句 主要 有 两 种 形式 ,其 一 是 单 表 查询 的 语句 格式 ,其 二 是 多 表 连 接 
查询 的 语句 格式 。 

单 表 查 询 的 语句 格式 如 下 : 


Select < 列 名 >/< 统 计 函 数 式 >, …From < 表 名 > [Where < 条 件 式 >] [Group By < 分 组 列 > [Having < 分 组 
条 件 >]] [Order By < 排序 列 > ASC/DESC] 


多 表 连 接 查 询 的 语句 格式 如 下 : 
Select < 列 名 >, … From < 表 名 >,< 表 名 > Where < 连接 条 件 >[ and < 普通 条 件 式 >] 


2. 对 SQL 普通 查询 语句 格式 的 说 明 

在 SQL 查询 语句 的 基本 格式 中 ,凡是 用 尖 括 号 括 起 来 的 信息 都 是 可 以 变化 的 量 ,可 以 
用 具体 的 信息 代替 ,例如 * 表 名 ?被 用 尖 括 号 括 起 来 ,表示 这 个 地 方 应 该 用 一 个 具体 的 数据 表 
名 称 代 替 。 凡 是 用 方 括号 括 起 来 的 信息 都 是 可 以 省 略 的 信息 。 

在 此 格式 中 ,“Select << 列 名 之 ,… From 二 表 名 之 ?是 命令 的 基本 组 成 ,表示 从 指定 的 
数据 表 中 显示 指定 列 的 信息 。 例 如 “Select 姓名 ,性 别 ,单位 From 学 生 表 ”就 表示 从 学 生 
表 中 提取 “姓名 ,性 别 , 单 位 ”这 三 列 的 信息 显示 在 屏幕 上 。 

子 句 “Where 过 条 件 式 二 ”负责 限定 被 查询 记录 的 条 件 。 例 如 “Select 姓名 ,性 别 ,单位 
From 学 生 表 Where 性 别 =' 女 "就 表示 从 学 生 表 中 提取 女生 的 “姓名 ,性 别 , 单 位 ”这 三 列 的 
信息 显示 在 屏幕 上 ,“Where 性 别 = ' 女 ”限定 了 只 有 女生 的 信息 被 提取 。 

子 名 “Group By 到 分 组 列 盖 ?表示 对 指定 表 中 的 记录 进行 分 组 处 理 ,每 组 被 合并 为 一 
行 。 如 果 带 有 子 句 “Having 去 分 组 条 件 之 ”, 则 只 有 满足 分 组 条 件 的 行 显 示 出 来 。 

注意 : 子 句 “Having 去 分 组 条 件 二 ”必须 跟 在 “Group By 去 分 组 列 二 ”后 面 使 用 ,不 能 
独立 使 用 。 但 “Group By 去 分 组 列 二 ”可 以 不 带子 名 “Having 所 分 组 条 件 之 ”。 

子 句 “[Order By 所 排序 列 > ASC/DESCJ]” 表 示 对 查询 结果 排序 输出 。ASC 和 DESC 
两 者 只 能 保留 其 一 ,ASC 表示 升序 ,DESC 表示 降序 。 如 果 有 多 个 排序 关键 字 , 关 键 字 之 间 
以 “,” 分 割 。 

注意 : SQL 语句 的 子 句 顺序 基本 不 允许 变化 ,如 果 某 一 子 句 在 查询 语句 中 存在 , 则 一 定 
要 放 在 它 应 该 放置 的 位 置 上 。 

在 书写 SQL 语句 时 ,单词 之 间 应 该 用 英文 空格 分 隔 , 所 有 的 标点 符号 都 使 用 英文 方式 。 
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对 于 字符 囊 常量 需要 用 英文 的 单 引号 括 起 来 。 
5.3.3 SQL 单 表 查询 语句 示例 
1. 简单 查询 语句 
(1) 显示 出 学 生 的 所 有 信息 。 
Select * From 学 生 表 ; 
说 明 :“* ”代表 数据 表 中 的 所 有 字段。 
(2) 列 出 课程 "数据库 系 统 ” 的 基本 情况 。 
Select * From 课程 表 Where kcm = ' 数 据 库 系 统 '， 
(3) 列 出 编号 为 “YK002” 的 课程 被 选修 情况 ,显示 出 考试 成 绩 、 考 试 日 期 和 学 号 。 
Select xh, score, kstime From cjb Where kch = 'K002'; 
(4) 查询 学 分 在 2 一 3 分 之 间 的 课程 名 称 ,学 分 和 开课 单位 。 
Select kcm, xuefen, kkdw From 课程 表 Where xuefen<= 3 and xuefen>= 2; 


2. 对 字符 串 的 模糊 查询 

在 数据 管理 中 ,有 时 需要 进行 模糊 查询 。 例 如 ,查找 所 有 姓 “ 王 的 人 ,或 者 查找 姓名 中 
包括 “ 云 " 字 的 人 。 在 SQL 语言 中 ,一 般 用 “LIKE” 命 令 进行 模糊 查找 ,用 “%” 作 为 查找 通 配 
符号 。 

(1) 查找 所 有 姓 王 的 学 生 的 情况 。 

Select * From 学 生 表 Where xm Like ' 王 名 '; 

(2) 查找 所 有 课程 名 字 中 包括 “数据 ”的 课程 。 


Select * From 课程 表 Where kcm Like ' 名 数据 名 '; 


注意 ; 引号 内 的 英文 字符 串 区 分 大 小 写 。 

3. 唯一 性 查询 

在 实际 工作 中 ,有 时 需要 进行 唯一 性 查询 ,对 特定 字段 过 滤 掉 重复 记录 。 例 如 ,对 学 生 
表 的 单位 字段 进行 唯一 性 查找 ,可 以 知道 所 有 的 学 生来 源 于 哪 几 个 单位 。 对 课程 表 的 任课 
教师 进行 唯一 性 查找 ,可 以 知道 课程 由 哪些 教师 讲授 。 唯 一 性 查找 的 关键 字 是 Distinct。 

(1) 列 出 学 生 表 中 学 生 的 所 属 单位 。 


Select Distinct dwei From 学 生 表 ; 
(2) 列 出 课程 表 中 的 开课 单位 。 
Select Distinct kkdw From 课程 表 ; 


4. 计算 查询 
为 了 在 数据 检索 过 程 中 实现 计算 ,SQL 语言 提供 了 一 些 统计 函数 。SQL 中 常用 的 统计 
函数 有 5 个, 分别 是 Sum( 数 值 型 列 ) ,Count( 列 名 或 * ) ,MAX( 数 值 型 列 ) ,MIN (数值 型 
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列 ),Avg( 数 值 型 列 )。 其 含义 依次 为 求 和 , 求 个 数 \ 求 最 大 值 求 最 小 值 . 求 平均 值 。 

除了 Count 函数 可 以 用 各 种 类 型 的 列 、 或 者 ** ”作为 参数 外 ,其 他 函数 都 只 能 以 一 个 
数值 型 列 或 者 数值 型 表达 式 作 为 参数 ,表示 对 指定 列 中 符合 条 件 的 记录 进行 求 和 、 求 最 大 
值 , 求 最 小 值 和 求 平均 值 的 计算 。 

(1) 求 出 所 有 学 生 的 奖学金 之 和 

Select Sum(jlje) Fron 学 生 表 ; 

执行 上 述 语句 后 ,系统 将 计算 出 一 个 数字 ,这 个 数字 的 字段 名 称 默认 为 “sum_jlje”, 这 
个 字段 名 不 符合 中 国人 习惯 ,人 们 更 习惯 于 给 这 个 数字 一 个 别名 。 语 句 如 下 : 

Select Sum(jlje) AS 奖学金 总 额 From 学 生 表 ; 
其 中 “AS 奖学金 总 额 "说明 以 "奖学金 总 额 ” 作 为 “Sum(jlie)” 的 别名 。 

(2) 求 出 学 分 最 高 的 课程 的 学 分 

Select MAX(xuefen) as 最 高 学 分 Fronm 课程 表 ; 

(3) 求 出 经 济 管理 学 院 的 学 生 的 平均 奖学金 金额 

Select hvg(jlje) as 平均 奖金 From 学 生 表 Where dwei = ' 经 济 管理 学 院 '; 

(4) 求 出 “S002” 号 学 生 参加 的 所 有 考试 获得 分 数 的 之 和 

Select Sum( score) as 总 成 绩 From 成 绩 表 Where xh= 'S002'; 

(5) 求 课程 表 中 “物理 系 ”开设 的 课程 的 平均 学 分 

Select Avg(xuefen) as 平均 学 分 From 课程 表 Where kkdw = ' 物 理 系 '; 

5, 分 组 查询 

所 谓 分 组 查询 是 指 先 按照 某 一 关键 字 对 记录 分 组 ,然后 对 同一 组 中 的 记录 进行 计算 ,最 
后 使 每 组 记录 只 生成 一 条 结果 记录 。 分 组 查询 中 使 用 关键 词 Group by 对 记录 进行 分 组 。 

例如 ,在 学 生 表 中 ,如 果 需 要 知道 每 一 个 单位 内 部 全 体 学 生 的 “生活 补贴 ”的 平均 值 , 就 
需要 先 按照 单位 对 学 生 进 行 分 组 ,然后 对 同 组 中 的 学 生计 算 其 生活 补贴 的 均值 。 其 关键 词 
是 “Group by dwei” 和 “Avg(jlje)”。 

(1) 求 出 每 个 单位 中 学 生 奖 学 金 的 平均 值 

Select dwei, hvg(jlje) as 平均 奖学金 From 学 生 表 Group By dwei; 

(2) 求 出 每 个 学 生 的 选课 总 门 数 

Select xh, Count( * ) as 总 门 数 Fronm 成 绩 表 Group By xh; 

(3) 求 出 每 个 单位 中 的 最 高 奖学金 金额 

Select 单位 , MAX( jlje) as 最 大 额 From 学 生 表 Group By dwei; 

(4) 求 出 每 位 同学 的 平均 考试 成 绩 


Select xh,，Avg( score) as 平均 成 绩 From 成 绩 表 Group By xh; 
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(5) 求 每 门 课程 的 选课 人 数 及 考试 平均 成 绩 

Select kch, Count( * ) as 人 数 , Avg( score) as 平均 成 绩 From 成 绩 表 Group By kch; 

(6) 求 出 平均 成 绩 85 分 以 上 的 学 生 及 其 平均 成 绩 

Select xh, Avg( score) as 平均 成 绩 Fronm 成 绩 表 Group By xh Having Avg(score)>= 85; 

注意 : 平均 成 绩 在 数据 表 中 不 存在 ,是 由 公式 “Avg( 考 试 成 绩 )” 计 算 获得 的 ,是 一 个 统 
计 结 果 , 而 不 是 普通 条 件 式 , 不 能 放 在 Where 后 边 。Where 后 边 只 能 是 字段 名 直接 构成 的 
普通 条 件 式 ,而 基于 分 组 计算 结果 的 条 件 式 必须 放 在 关键 词 *Having” 后 面 。 

(7) 查询 至 少 选修 过 三 门 课程 的 学 生 的 学 号 和 平均 成 绩 

Select 学 号 , Avg( score) as 平均 分 From 成 绩 表 Group By 学 号 Having Count( * )>=3; 

(8) 求 出 选修 人 数 在 20 人 以 上 且 平 均 成 绩 在 90 分 以 上 的 课程 


Select kch From 成 绩 表 group by kch Having Count( * )>= 20 AND Avg( score)> = 90; 


注意 ; 在 分 组 查询 中 ,只 有 分 组 列 和 被 统计 列 有 现实 意义 ,所 以 在 分 组 查询 中 ,Select 
命令 后 的 列 名 只 能 是 分 组 字段 和 统计 列 ,不 允许 出 现 其 他 字段 名 。 例 如 ,在 求 出 每 个 单位 中 
学 生 的 “奖学金 ?的 平均 值 时 ,只 有 单位 名 称 和 平均 值 有 意义 。 由 于 同 组 记录 的 信息 已 经 合 
并 ,单个 学 生 的 姓名 、 学 号 等 数据 已 经 没有 现实 意义 。 


5.3.4 SQL 多 表 查 询 


1. SQL 多 表 查 询 的 概念 

在 数据 查询 中 ,如 果 查 询 条 件 或 者 输出 字段 来 自 不 同 的 数据 表 , 则 应 该 利用 连接 查询 。 
即 首先 要 求 两 个 或 多 个 数据 表 依 据 关键 字段 建立 连接 ,形成 一 个 综合 多 表 字段 的 虚 表 , 然 后 
在 连接 结果 的 基础 上 实施 数据 筛选 工作 。 

2. SQL 的 多 表 查 询 语句 的 格式 

多 表 连 接 查询 的 语句 格式 如 下 : 


Select < 列 名 >, … From < 表 名 >,< 表 名 > Where < 连接 条 件 >[and < 普通 条 件 式 >] 


3, SQL 多 表 查 询 示例 

(1) 查询 “ 刘 云 平 " 的 学 号 .选修 过 的 课程 的 名 字 ,考试 成 绩 、 所 在 单位 .性别 和 奖学金 

Select 学 生 表 . xh, xm, dwei, kcm, score, xb, jlje 

Fron 学 生 表 , 成 绩 表 ,课程 表 

Where 学 生 表 . xh= 成 绩 表 . xh and 成 绩 表 . kch= 课程 表 . kch 

and xm= ' 刘 云 平 '; 

(2) 列 出 “教育 学 院 ” 的 每 个 学 生 的 学 号 、 姓 名、 选课 总 门 数 和 平均 成 绩 , 结果 按照 姓名 
升序 排列 


Select xh, xm, Count( * ) as 选课 门 次 , Avg( score) as 平均 成 绩 
From 学 生 表 , 成 绩 表 
Where 学 生 表 .xh= 成 绩 表 . xh AND dwei = ' 教 育 学 院 ' 
Group By 成 绩 表 . xh, xm Order By xm asc; 
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注意 : 由 于 在 两 个 表 中 都 没有 选课 总 门 数 和 平均 成 绩 字段 ,因此 肯定 不 能 直接 连接 得 
出 结果 。 思 考 一 下 ,虽然 在 两 个 表 中 都 没有 选课 总 门 数 和 平均 成 绩 字 段 , 但 这 两 个 字段 是 可 
以 通过 成 绩 表 直接 计算 出 来 的 。 因 此 ,可 以 直接 对 学 生 表 和 成 绩 表 实施 连接 查询 ,然后 再 进 
行 分 组 计算 。 


5.3.5 SQL 更 新 语句 


1. 删除 记录 
在 SQL 语句 中 利用 Delete 语句 删除 记录 ,其 命令 格式 如 下 : 


Delete From < 表 名 > [Where < 删除 条 件 >] 


其 含义 是 从 指定 的 表 中 删除 满足 条 件 的 记录 。 这 个 命令 本 身 很 简单 ,难点 在 于 “删除 条 
件 ” 的 书写 ,描述 被 删除 记录 的 “删除 条 件 ” 可 以 是 一 个 简单 条 件 式 ,也 可 以 是 一 个 榜 套 的 查 
询 条 件 。 

(1) 从 学 生 表 中 删除 学 生 “ 李 一 兆 ” 

Delete Fron 学 生 表 Where xm = ' 李 一 兆 '; 


注意 : 如 果 学 生 表 、 成 绩 表 和 课程 表 之 间 建 立 了 限制 级 外 键 约束 ,在 “ 李 一 兆 "有 选课 记 
录 的 情况 下 将 不 能 删除 学 生 表 中 关于 “ 李 一 兆 ”的 记录 。 如 果 学 生 表 , 成 绩 表 和 课程 表 之 间 
建立 了 级 联 级 外 键 约束 ,在 “ 李 一 净 ”有 选课 记录 的 情况 下 删除 学 生 表 的 “ 李 一 兆 ”, 将 会 自动 
删除 成 绩 表 中 与 “ 李 一 光 ”有关 的 选课 记录 。 

(2) 从 学 生 表 中 删除 没有 选修 过 课程 的 学 生 的 信息 


Delete From 学 生 表 Where xh Not in (Select xh Fronm 成 绩 表 ) ; 


2. 添加 记录 

向 数据 表 中 添加 记录 也 是 对 数据 表 更 新 操作 中 常用 的 方法 ,其 常用 的 命令 格式 有 以 下 
两 种 。 

(1) 向 表 中 添加 指定 值 的 新 记录 

Insert into < 数据 表 名 >(< 字 有 段 名 >,< 字 有 段 名 >, … ) Values( 值 , 值 , …) 

注意 ; D 如 果 要 对 数据 表 中 的 所 有 字段 输入 数据 , 则 数据 表 名 后 的 字段 名 列表 可 以 省 
略 ; @ 以 SQL 语句 向 数据 表 中 插入 记录 的 时 候 , 对 于 字符 型 常量 要 用 单 引号 括 起 来 ; 
SQL 语句 中 只 能 把 记录 添加 到 表 末 尾 , 没 有 向 数据 表 的 中 间 位 置 插 入 记录 的 功能 。 

例如 ,向 学 生 表 中 添加 一 名 新 学 生 ,信息 为 "学 号 : 11223319; 姓名 : 王 丽 兰 ; 单位 : 哲 
学 学 院 ; 性 别 : 女 ”。 

Insert Into 学 生 表 (xh, xm, dwei, xb) 

Values('11223319', ' 王 丽 兰 ', "哲学 学 院 , ' 女 '); 


(2) 把 甲 表 中 的 记录 添加 到 乙 表 


Insert Into < 乙 表 >(< 字 段 名 >, … ) 
Select < 列 名 >, … From < 甲 表 > Where < 条 件 式 > 
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例如 ,已 知 数据 表 “Wuli” 与 学 生 表 结 构 相 同 , 现 在 需要 把 “学 生 表 ”中 物理 系 学 生 的 信 
息 添加 到 数据 表 “Wuli” 中 。 

Insert Into Wuli 

Select * From 学 生 表 Where dwei = ' 物 理 系 '; 

3. 修改 记录 的 值 

对 数据 表 中 的 记录 实施 修改 的 命令 格式 如 下 : 


Update < 表 名 > Set < 字段 名 > = < 式 子 > [Where < 替换 条 件 >] 


这 个 命令 的 作用 是 修改 某 些 字段 的 值 ,Update 可 以 修改 选 定 记录 的 某 个 字段 的 值 。 其 
基本 格式 比较 简单 ,但 在 实际 的 应 用 中 ,替换 条 件 ” 的 书写 可 能 比较 复杂 ,因为 “ 蔡 换 条 件 ” 
可 以 是 一 个 简单 条 件 式 ,也 可 以 是 一 个 赃 套 的 查询 条 件 。 

(1) 按照 教育 学 院 学 生 奖 学 金 增 加 100 元 的 方式 重新 计算 全 体 学 生 的 奖学金 


Update 学 生 表 Set jlje = jlje+ 100 Where dwei = ' 教 育 学 院 '; 
(2) 对 于 选修 课程 K002 且 成 绩 及 格 的 女生 ,其 奖学金 增加 200 元 


Update 学 生 表 Set jlje= jlje+ 200 Where xh in 
(select xh from 成 绩 表 Where kch = 'K002' And Score>= 60) 


(3) 对 选课 门 数 在 3 门 以 上 , 且 平 均 成 绩 在 85 分 以 上 的 同学 ,其 奖学金 增加 1200 元 


Update 学 生 表 Set jlje = jlje + 1200 Where xh in (Select xh From 成 绩 表 Group By xh Having 
Count( * )>=3 and Avg(Score) = 85) 


假 考题 


1. SQL Server 2005 是 一 个 什么 系统 ? 在 数据 管理 中 有 什么 优势 ? 

2. 如 何 启 用 VS2008 的 服务 器 资源 管理 器 ? 如 何 使 用 服务 器 资源 管理 器 中 的 树 状 
结构 ? 

3. 如 何在 服务 器 资源 管理 器 中 创建 数据 连接 ? 如 何 设置 DataSource 属性 的 值 ? 使 用 
哪 一 个 符号 可 以 表示 当前 计算 机 中 的 SQL Server 服务 器 ? 

4. 如 何 利用 “服务 器 资源 管理 器 "创建 新 的 SQL Server 数据 库 ? 

5. 如 何在 “数据 连接 ”中 创建 数据 表 并 为 数据 表 设 置 主键 ? 

6. 如何 为 数据 表 中 的 记录 设置 自动 增长 数值 的 记录 编号 (ID)? 

7. 什么 是 数据 表 之 间 的 关联 ?如何 设置 数据 表 之 间 的 联系 ? 数据 表 之 间 的 联系 是 以 
什么 方法 实现 的 ? 

8. 在 “服务 器 资源 管理 器 "中 如 何 实现 查询 操作 ? 

9. SQL 查询 语句 的 一 般 格式 是 什么 ? 

10. 如 何 利 用 SQL 语句 实现 记录 插入 ? 

11. 如 何 使 用 SQL 语句 实现 记录 删除 ? 

12. 利用 SQL 实现 记录 更 新 语句 的 一 般 格 式 是 什么 ? 
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侍 机 实 训 是 


启用 服务 器 资源 管理 器 ,利用 “数据 连接 ”创建 新 的 “商品 销售 系统 数据 库 ”( 数 据 库 名 称 
为 SPGL) ,然后 完成 以 下 操作 。 

(1) 创建 数据 库 与 数据 表 。 

@ 在 数据 库 中 建立 三 张 数据 表 : 商品 表 、 售 货 员 表 ,销售 明细 表 。 表 结构 如 下 : 

商品 表 ( 商 品 号 ,商品 名 ,产地 , 供 货 商 ,进货 价 ) 

售货员 表 (售货员 号 ,姓名 ,性 别 , 部 门 ,生日 ,工资 ,奖金 ,年 龄 ,实际 收入 ) 

销售 明细 表 ( 商 品 号 ,单位 ,销售 价 , 数 量 , 销 售 金额 ,销售 日 期 ,售货员 号 ) 

@ 设置 商品 表 的 主键 为 商品 号 ,售货员 表 的 主键 为 售货员 号 ; 然后 向 各 个 数据 表 中 输 
人 若干 条 记录 。 输 入 过 程 中 注意 记录 之 间 的 约束 关系 。 

@ 建立 商品 表 、 售 货 员 表 和 销售 明细 表 之 间 的 参照 关系 。 

@ 为 数据 库 输 入 若干 条 记录 。 

(2) 在 完成 上 述 操作 的 基础 上 ,以 SQL 语句 实现 下 列 操作 。 

@ 查询 商品 “帽子 ”的 编号 ,进货 价 、 供 应 商 和 曾经 出 售 帽子 的 售货员 的 编号 ,姓名 ,性 
别 、 销 售 价格 、 销 售 数量 和 销售 日 期 。 

@ 根据 “销售 额 = 销 售 价 X 数 量 ” 的 规则 计算 出 销售 明细 表 中 每 笔 生意 的 销售 额 。 

@ 计算 每 个 部 门 中 售货员 的 平均 工资 和 平均 奖金 。 

@ 对 于 销售 总 金额 在 2000 元 以 上 的 售货员 ,其 奖金 增加 500 元 。 
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学 习 要 点 

本 章 主要 学 习 在 ASP.NET 下 以 SqlDataSource 技术 实现 数据 库 访问 的 技术 ,要 求 了 
解 SqlDataSource 控件 的 属性 及 方法 ,并 能 结合 GridView 和 FormView 控件 完成 大 多 数 的 
数据 表 访问 程序 的 设计 。 本 章 要 求 重点 关注 以 下 内 容 : 
SqlDataSource 控件 的 ConnectionString、DataSourceMode 属性 的 设置 。 
分 别 以 界面 操作 方式 .填写 SQL 语句 方式 为 SqlDataSource 控件 赋予 SelectCommand、 
UpdateCommand ,InsertCommand DeleteCommand 命令 的 技术 。 
Insert() 方 法 和 Update() 方 法 的 应 用 技术 。 
GridView 控件 与 SqlDataSource 控件 建立 关联 的 技术 。 
GridView 的 编辑 列 技术 、GridView 的 模板 列 设计 技术 。 
获取 GridView 选 定 行 和 当前 行 的 技术 ,获取 指定 行 、 指 定 列 数据 的 方法 。 
FormView 的 默认 视图 .FormView 模板 列 的 设计 。 


6.1 ASP.NET 访问 数据 库 技 术 简介 


1. ASP.NET 访问 数据 库 的 主要 技术 

为 了 访问 数据 库 ,使 Web 页 面 能 够 便利 地 读 取 数 据 库 中 的 内 容 并 呈现 出 来 ,ASP.NET 
提供 了 多 种 访问 数据 库 的 方法 。 总 的 看 来 ,主要 有 以 下 两 种 方式 。 

(1) 基于 Connection 对 象 的 技术 ,包括 Command 和 DataAdapter 技术 。 

(2) 基于 DataSourceControl 的 技术 ,包括 sqlDataSource 技术 和 LINQ 技术 。 

从 技术 处 理 能 力 看 ,Command 和 DataAdapter 技术 建立 在 Connection 的 基础 上 ,对 数 
据 库 的 操作 涉及 较 多 的 编程 知识 ,对 开发 者 的 编程 能 力 要 求 高 ; SqlDataSource 是 .NET 3.5 
新 提供 的 技术 ,可 以 以 非常 少 的 编码 实现 完整 的 数据 库 操作 ,是 一 个 功能 强大 的 控件 ,但 是 
它 对 系统 资源 的 要 求 较 大 。LINQ 技术 是 在 ASP.NET 语句 的 编程 框架 下 直接 操作 数据 
库 的 一 种 模式 , 它 把 数据 库 看 成 高 级 语言 中 的 对 象 , 把 数据 库 操作 语言 与 .NET 的 编程 
语言 整合 为 一 体 ,使 得 对 数据 库 的 访问 可 以 不 用 SQL 语言 而 直接 使 用 LINQ, 从 而 使 编译 
器 也 能 够 检查 数据 库 操作 语句 的 语法 错误 ,针对 数据 库 的 操作 也 能 在 ASP.NET 的 体系 下 
完成 。 

2. ASP. NET 数据 操作 控件 的 智能 菜单 

由 于 ASP.NET 的 数据 库 访问 控件 都 比较 复杂 ,有 较 多 的 属性 配置 和 方法 设计 。 为 便 
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于 开发 者 使 用 ,VS2008 为 窗 体 中 的 每 个 数据 库 访问 控件 提供 了 智能 设置 按钮 ,简称 为 " 智 
能 按钮 ”。 此 按钮 位 于 数据 库 访问 控件 的 右上 角 ,在 控件 被 选中 时 呈现 出 来 。 单 击 此 按钮 ， 
会 弹出 一 个 可 快速 配置 此 控件 的 小 菜单 ,此 菜单 称 为 智能 菜单 ,如 图 6-1 所 示 。 开 发 者 可 利 
用 此 菜单 便捷 地 完成 针对 数据 库 访问 控件 的 各 种 配置 工作 。 


图 6-1 Web 数据 库 控件 的 智能 菜单 示意 图 


6.2 DataSource 技术 简介 


DataSource 控件 主要 用 于 实现 从 不 同 数据 源 获取 数据 的 功能 ,包括 了 SqlDataSource 
(派生 AccessDataSource )、LinqDataSource、ObiectDataSource、XMLDataSource 和 
SiteMapDataSource。 这 5 种 数据 源 控 件 分 别针 对 不 同 的 数据 类 型 ,为 不 同 的 数据 类 型 提供 
了 统一 的 数据 处 理 方式 。 本 节 主 要 讨论 SqlDataSource 控件 。 


6.2.1 SqlDataSource 控件 简介 


1. SqlDataSource 控件 的 设计 目标 

SqlDataSource 控件 的 应 用 非常 广泛 ,被 用 于 访问 各 类 关系 数据 库 ,包括 Access、SQL 
Server、Oracle 等 DBMS, 甚至 可 以 连接 ODBC 数据 源 。 当 一 个 具体 的 数据 库 被 以 
SqlDataSource 连接 时 ,就 屏蔽 了 这 种 数据 库 的 个 性 化 特点 ,可 以 使 用 一 种 统一 的 处 理 模式 
进行 操作 。 

SqlDataSource 控件 的 功能 非常 强大 ,把 数据 库 连接 查询、 删除、 修改 .插入 整合 在 统一 
的 体系 下 ,允许 直接 把 控件 .变量 .Session 等 以 参数 的 方式 绑 定 到 SqlDataSource 对 象 上 ， 
几乎 不 需要 编写 代码 就 能 实现 比较 完整 的 数据 库 操作 。 

2. SqlDataSource 访问 数据 库 的 基本 思路 

SqlDataSource 访问 数据 库 建立 在 连接 的 基础 上 ,由 于 在 SqlDataSource 内 部 已 经 集成 
了 数据 连接 功能 ,因此 只 须 为 SqlDataSource 提供 连接 字符 串 (ConnectionString) 就 能 自动 
实现 数据 库 连 接 。 

在 数据 库 连接 完成 后 ,通过 为 SqlDataSource 对 象 的 SelectQuery、 DeleteQuery、 
InsertQuery、UpdateQuery 属性 绑 定 SQL 语句 ,并 为 SQL 语句 绑 定 参 数 ,就 能 便利 地 实现 
针对 数据 库 的 各 种 操作 。 


6.2.2 SqlDataSource 控件 的 关键 属性 与 方法 
SqlDataSource 控件 的 关键 属性 与 方法 如 表 6-1 所 示 。 
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表 6-1 SqlDataSource 控件 的 关键 属性 与 方法 


属性 /方法 取 值 说 明 
连接 字符 串 中 包含 数据 库 类 型 、 名 称 ,用户 

ConnectionString 一 a i al 

交接 归 各 入 | 连接 申 的 内 容 由 web config 提供 

获取 内 存 数 据 库 , 可 更 新 、 读 取 数 据 库 中 的 

DataSet 
DataSourceMode 数据 

DataReader 获得 只 能 读 取 的 数据 库 
SelectQuery SQL 语句 带 有 参数 的 SQL 查询 语句 (Select) 
SelectCommand SQL 语句 /存储 过 程 名 SQL 查询 语句 或 存储 过 程 名 
Galeri Text 查询 命令 的 类 型 是 Select 语句 

StoredProcedure 查询 命令 的 类 型 是 存储 过 程 
InsertQuery 带 有 参数 的 SQL 插入 语句 (Insert) 
InsertCommand SQL 语句 /存储 过 程 名 Insert 语句 或 存储 过 程 名 
Te Text 插入 命令 的 类 型 是 Insert 语句 

StoredProcedure 插入 命令 的 类 型 是 存储 过 程 
Insert() 方 法 实施 插入 操作 
DeleteQuery 带 有 参数 的 SQL 删除 语句 (Delete) 
DeleteCommand SQL 语句 /存储 过 程 名 Delete 语句 或 存储 过 程 名 
i Text 删除 命令 的 类 型 是 Delete 语句 

StoredProcedure 删除 命令 的 类 型 是 存储 过 程 
UpdateQuery 带 有 参数 的 SQL 更 新 语句 (Update) 
UpdateCommand SQL 语句 /存储 过 程 名 Update 语句 或 存储 过 程 

Text 更 新 命令 的 类 型 是 Update 语句 
PO er 更 新 命令 的 类 型 是 存储 过 各 
Update() 方 法 实施 更 新 操作 


6.2.3 SqlDataSource 控件 创建 


在 Web 窗 体 的 [设计 了 视图 下 ,要 建立 SqlDataSource 对 象 有 两 种 常见 的 方法 : 通过 “ 服 
务 器 资源 管理 器 ”创建 SqlDataSource 对 象 和 直接 从 [工具 箱 】 中 创建 SqlDataSource 对 象 。 

对 于 这 两 种 方法 ,笔者 推荐 使 用 前 者 ,因为 前 者 已 经 自动 完成 了 SqlDataSource 配置 的 
绝 大 多 数 工作 ,能够 极 大 地 提升 开发 效率 。 

1. 利用 “服务 器 资源 管理 器 ”自动 创建 SqlDataSource 

首先 ,打开 【服务 器 资源 管理 器 了 面板 ,建立 数据 连接 。 

接着 ,把 “数据 连接 ”下 的 一 个 数据 表 直 接 拖 动 到 Web 窗 体 的 适当 位 置 ,系统 会 自动 在 
Web 窗 体 中 创建 一 个 SqlDataSource 控件 和 一 个 GridView 控件 。 

此 时 ,如 果 以 浏览 器 浏览 此 窗 体 ,会 发 现 能 够 以 列表 方式 显示 出 相应 数据 表 的 内 容 , 表 
示 此 SqlDataSource 控件 已 经 创建 成 功 ,并 自动 完成 了 必要 的 配置 ,如 图 6-2 所 示 。 

2. 利用 [工具 箱 】 创 建 SqlDataSource 

1) 向 窗 体 中 添加 SqlDataSource 控件 

(1) 从 【工具 箱 】 中 “数据 ?栏目 下 拖 动 SqlDataSource 控件 到 Web 窗 体 的 左上 角 , 则 创 
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建 一 个 名 字 为 SqlDataSourcel 的 对 象 。 

(2) 单 击 SqlDataSourcel 对 象 右上 角 的 智能 按钮 ,从 智能 菜单 中 选择 [配置 数据 源 】, 则 
立即 打开 【新 建 连接 】 对 话 框 ,从 中 选择 一 个 已 有 的 连接 ,并 同意 把 连接 字符 串 添加 到 应 用 程 
序 的 配置 文件 中 。 然 后 , 单 击 [ 下 一 步 ] 按 钮 。 


音 DW 大 助 山 
和 加: 司 -成 品 呈 | 帮 己 双 | 可- 人 .s.r ~ 


1 ; 晶 昌 | 且 吉 到 | 三 全 | xhrMtl0Tanstcz| 入 目 :四 


es sbe |abe |abe 201124 
由 区 max | 一 
南国 mad he |abe |abe |201124 
中 加 00000 
所 回 表 201124 
| 中 国 abe abe abe 00000 
[| 
| 2011214 
后 国宾 上 |abe abe abe 00o000 
Ee 
由 国 abc |abe |abe 2011214 
$B Ss O0000 
六 | SqlDatasource -SqlDataSourcel 
中 国 疙 站 一 一 | 
| ’ 
[EE EA IE 
拖 动 边 尖 控 点 可 涯 行 34 到 24 


图 6-2 拖 动 “数据 表 ” 创 建 SqlDataSource 对 象 和 GridView 对 象 


此 时 系统 处 于 “配置 Select 语句 "状态, 而且 已 经 启动 了 与 SQL 语句 相关 的 配置 ,需要 
进行 比较 复杂 的 SQL 语句 生成 工作 ,界面 如 图 6-3 所 示 。 


图 6-3 配置 SqlDataSource 数据 源 和 选择 输出 列 


140 


动态 网 站 设计 与 开发 (ASP. NET 版 ) 


2) 配置 SqlDataSource 数据 源 

(1) 选择 输出 项 。 即 通过 中 部 【 列 ] 的 数据 项 复 选 框 选择 要 输出 哪些 列 , 复 选 框 中 有 对 
勾 的 列 将 被 输出 。 其 中 “x ”代表 输出 全 部 列 。 

(2) 进行 记录 筛选 。 即 单 击 右 侧 的 WHERE 按钮 ,就 会 打开 对 数据 进行 筛选 的 对 话 
框 ,如 图 6-4 所 示 。 


向 语句 的 WHERE 子 句 中 添 四 或 多 个 条 件 。 可 为 每 个 条 件 指定 文本 全 或 参数 的 值 ， 参 数 化 的 信和 运行 时 要 各 其 居 性 
lO: 多 性 
沪 本 皖 隆 IDO 
运算 生 : et 
本 四 MV): 
(S): 

Control | 

SQL Rt: 和 

bh] = @xh TextBoxl.Text 
WHERE 3W): 

SQL 有 全 


图 6-4 设置 WHERE 子 句 的 参数 并 绑 定 控件 


此 时 可 以 选择 列 名 、 运 算 符 和 查询 值 ,通过 把 “ 列 名 运算 符 查询 值 ?组 成 一 个 条 件 表 达 
式 来 表达 数据 筛选 的 语义 。 例 如 要 查找 学 号 等 于 文本 框 TextBoxl 的 值 的 所 有 记录 ,就 可 
以 在 [ 列 ] 下 选择 “xh”,【 运 算 符 ] 选 择 “ 二 ”,【 源 选择 “Control”,【 控 件 ID】 选 择 “TextBox1”。 此 
时 就 会 在 [SQL 表达 式 : ] 文 本 框 中 出 现 “[xh] 二 @xh”,【 值 : ] 文 本 框 中 出 现 “TextBox1. Text”。 
单 击 【 添 加 ] 按 钮 后 会 在 [WHERE 子 句 】 框 中 出 现 “[xh] 王 @xh TextBoxl. Text”。 通 过 这 
种 可 视 化 的 配置 ,实现 SQL 语句 的 撰写 。 

(3) 如 果 图 6-3 右 侧 的 【只 返回 唯一 行 ] 复 选 框 被 选中 , 则 重复 的 记录 将 被 合并 为 一 行 ， 
这 一 功能 具有 重要 价值 。 例 如 , 想 从 学 生 表 中 查找 单位 字段 共有 哪些 取 值 ,就 需要 选中 此 复 
选 框 ,以 免 同 一 单位 的 名 称 多 次 重复 出 现 。 

(4) 单 击 图 6-3 右 侧 的 按钮 ORDER BY, 可 以 设置 记录 按照 哪个 字段 排序 输出 。 

(5) 单 击 图 6-3 右 侧 的 [高 级 ] 按 钮 ,可 以 打开 一 个 设置 记录 更 新 语句 的 对 话 框 ,如 图 6-5 
所 示 。 如 果 当 前 数据 表 已 经 设置 主键 ,只 要 使 复 选 框 [生成 INSERT、UPDATE 和 
DELETE 语句 J 有效 ,就 会 自动 配置 InsertQuery、UpdateQuery 和 DeleteQuery 语句 。 

(6) 单 击 【确定 ] 按 钮 ,确认 对 SqlDataSourcel 对 象 的 配置 。 

注意 : 如 果 选 定 的 数据 表 没 有 设置 主键 , 则 无 法 生成 InsertQuery、UpdateQuery 和 
DeleteQuery 语句 。 此 时 ,其 【高 级 SQL 生成 选项 对 话 框 的 【生成 INSERT .UPDATE 和 
DELETE 语句 ] 复 选 框 是 灰色 的 ,无 法 设置 。 
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可 以 生成 附 h0 的 INSERT、UPDATE 和 DELETE 语句 来 更 新 数据 源 . 
同 生成 INSERT、UPDATE 和 DELETE 语句 (G) 


基于 SELECT 语句 生成 INSERT、UPDATE 和 DELETE 盘问 。 作 须 壬 定 所 有 主体 字 
段 才能 启用 此 运 项 , 


问 使 用 开放 式 并 发 (D) 


修改 UPDATE 和 DELETE 再 名 以 检测 自 该 记录 加 载 到 DataSet 中 以 来 数 握 库 是 否 更 
改 。 这 有 助 于 防止 并 发 冲 庄 。 


Cw |] ww | 


图 6-5 自动 生成 并 绑 定 更 新 语句 


6.2.4 SqlDataSource 控件 的 配置 


对 于 Web 窗 体 中 已 经 初步 配置 的 SqlDataSource 对 象 , 开 发 者 还 可 以 利用 【属性 了 面板 
修改 其 配置 信息 。 

1. 配置 SqlDataSource 的 基本 属性 

选中 Web 窗 体 中 的 SqlDataSource 对 象 , 打开 【属性 了 面板 ,从 【属性 了 面板 中 设置 其 
属性 。 

1) 修改 ConnectionString 属性 ,设置 正确 的 连接 字符 串 

例如 ,要 连接 本 地 服务 器 上 的 数据 库 XSGL, 使 用 Windows 方式 验证 , 则 使 用 连接 字符 
串 为 ， 

Data Source = . \sqlexpress; Initial Catalog = XSGL; Integrated Security = True; Pooling = False 


2) 设置 SqlDataSource 结果 模式 

修改 DataSourceMode 属性 ,设置 正确 的 模式 。 通 常 选择 为 “DataSet” 模 式 , 但 如 果 只 是 
使 用 查询 操作 ,也 可 以 使 用 DataReader 模式 。 

2. 配置 SqlDataSource 的 数据 库 操作 语句 

选中 Web 窗 体 中 的 SqlDataSource 对 
象 ,打开 其 [属性] 面板 后 ,可 通过 【属性 ] 面 [ows x 3 Do | 

i “|| 总 /使 回 | 目 国 | 六 

板 直 接 设置 各 种 SQL 语句 及 其 参数 。 er necooeeie AGEL | 

1) 配置 SelectQuery 属性 Sqlpatasourcel System Web ULWebControlssqlDataSource - 

首先 ,在 SqlDataSource 对 象 的 【属性 】 Ea 
面板 中 ,选中 SelectCommandType 属性 , 设 
置 为 Text, 表 示 使 用 SQL 语句 实现 数据 查 
询 ,如 图 6-6 所 示 。 

接着 , 单 击 SelectQuery 属性 后 边 的 小 
按钮 名 ,启动 查询 语句 设计 状态 ,打开 【命令 
和 参数 编辑 器 ] 对 话 框 ,如 图 6-7 所 示 。 

在 此 窗口 下 ,默认 为 输出 所 有 的 记录 。 图 6-6 启动 SelectQuery 查询 并 配置 参数 
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但 开发 者 也 可 通过 修改 配置 ,使 数据 源 只 输出 指定 的 记录 。 常 见 的 方法 是 : 通过 添加 参数 
并 绑 定 参数 源 ( 参 数 的 值 可 取 自 控件 或 者 Session 变量 等 ) ,建立 参数 与 窗 体 控件 之 间 的 联 
系 , 然 后 利用 【查询 生成 器 了 设计 出 带 有 参数 的 SQL 语句 ,从 而 使 SQL 语句 与 窗 体 中 的 控件 
(或 Session 变量 等 ) 有 机 地 结合 在 一 起 ,就 解决 了 利用 控件 控制 记录 输出 的 问题 。 


SELECT 命 S(G: 
SELECT (xhl, Baml lxb], [csdate], [dweil, [zhyel [phonel Bie] FROM [学 生 于 | 


图 6-7 在 [命令 和 参数 编辑 器 ] 对 话 框 中 为 SelectQuery 配置 参数 、 绑 定 参数 值 


2) 配置 DeleteQuery、InsertQuery 等 属性 

首先 ,在 图 6-6 中 选中 DeleteCommandType 属性 ,设置 为 Text, 表 示 使 用 SQL 语句 实 
现 数据 删除 。 

接着 , 单 击 DeleteQuery 属性 后 边 的 小 按钮 回 ,启动 查询 语句 设计 状态 ,打开 【命令 和 
参数 编辑 器 状态 对话 框 ,如 图 6-8 所 示 。 


DELETE 命令 (CO): 
ELETE FROM [学 生 胡 ] WHERE lxh] = @xh 


6-8 ”在 [命令 和 参数 编辑 器 ] 对 话 框 中 设置 删除 语句 的 参数 及 参数 值 
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在 [命令 和 参数 编辑 器 ] 对 话 框 中 , 先 添加 参数 并 绑 定 参数 源 ( 参 数 的 值 可 以 取 自控 件 或 
者 Session 变量 等 ) 。 然 后 ,利用 【查询 生成 器 设计 出 带 有 参数 的 SQL 语句 ,或 者 直接 在 
【Delete 命令 ] 列 表 框 中 输入 带 有 参数 的 SQL 语句 。 

配置 InsertQuery 命令 和 UpdateQuery 命令 的 方法 与 Delete 命令 相似 。 采 用 这 种 方 
法 ,几乎 不 用 编写 具体 的 代码 就 能 实现 数据 库 访问 操作 ,可 以 极 大 地 提高 编程 效率 。 


6.3 GridView 控件 与 FormView 控件 


6.3.1 GridView 控件 


GridView 是 一 个 以 二 维 表格 方式 输出 数据 的 控件 ,位 于 【工具 箱 了 的 【数据 ] 栏 目下 ,在 
实际 的 Web 应 用 开发 中 的 使 用 极为 广泛 。 和 其 他 控件 一 样 ,GridView 也 可 以 通过 【属性 】 
面板 修改 其 属性 。 另 外 , 单 击 GridView 对 象 右上 角 的 智能 按钮 ,就 能 够 打开 其 智能 菜单 ， 
进行 主要 的 设置 。 

1. GridView 控件 的 主要 属性 与 方法 

GridView 控件 的 主要 属性 与 方法 如 表 6-2 所 示 。 


表 6-2 GridView 控件 的 主要 属性 与 方法 


属性 /方法 取 值 说 有明 

DataSourceID 数据 源 标志 设置 GridView 的 数据 源 
DataKeyNames 字段 名 指明 数据 表 的 主键 字段 
AllowPaging 站 到 全 员 

false 不 允许 自动 分 页 
PageSize 数值 设置 每 页 的 记录 数目 
AllowSorting es dake ha 

false 不 允许 自动 排序 
Columns 是 个 集合 , 单 击 此 集合 可 进行 列 的 设置 
EditIndex 整数 值 指明 被 编辑 的 记录 的 序号 ,默认 为 一 1 
SelectedIndex 整数 值 被 选中 记录 的 序号 
SelectedValue 被 选中 记录 的 主键 值 
PageIndexChanging 事件 对 应 被 翻 页 时 要 执行 的 方法 
PageIndexChanged 事件 对 应 被 翻 页 后 要 执行 的 方法 
RowDeleting 事件 对 应 于 记录 被 删除 时 要 执行 的 方法 
RowDeleted 事件 对 应 于 记录 被 删除 后 要 执行 的 方法 
RowUpdating 事件 对 应 于 记录 被 修改 时 要 执行 的 方法 
RowUpdated 事件 对 应 于 记录 被 修改 后 要 执行 的 方法 
SelectedIndexChanging 事件 对 应 于 记录 被 选择 时 要 执行 的 方法 
SelectedIndexChanged 事件 对 应 于 记录 被 选择 后 要 执行 的 方法 
DataBind() 方 法 执行 一 次 数据 刷新 操作 
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2. GridView 控件 的 常见 设置 

1) 设置 分 页 显示 

以 [属性] 面板 设置 AllowPaging 属性 的 值 为 true, 而 且 可 以 同时 设置 PageSize 的 值 。 

2) 设置 显示 格式 

单 击 GridView 对 象 右上 角 的 智能 按钮 ,在 弹出 的 智能 菜单 中 选择 【自动 套用 格式 】, 然 
后 可 以 选择 一 种 GridView 的 显示 格式 。 

3) 选择 数据 源 

其 功能 是 为 GridView 选择 需要 显示 的 记录 的 来 源 ,通常 为 一 个 SqlDataSource 对 象 名 
称 ,或 者 是 DataTable .DataView 名 称 。 

具体 操作 时 ,可 单 击 GridView 对 象 右 上 角 的 智能 按钮 ,在 智能 菜单 中 为 GridView 选 
择 新 的 数据 源 。 

4) 启用 编辑 

其 功能 是 为 当前 GridView 添加 一 个 编辑 列 ,如果 单 击 编辑 列 中 链接 [编辑 】, 则 会 自动 
启动 编辑 功能 ,对 当前 记录 进行 编辑 。 

具体 操作 时 , 单 击 GridView 对 象 右上 角 的 智能 按钮 ,在 智能 菜单 中 选择 [启用 编辑 】 复 
选 框 ,就 可 以 了 。 

5) 启用 删除 

其 功能 是 为 当前 GridView 添加 一 个 删除 列 , 如 果 单 击 删除 列 中 链接 【删除 】, 则 会 自动 
启动 删除 功能 ,把 当前 记录 从 数据 表 中 删 掉 。 

具体 操作 时 , 单 击 GridView 对 象 右上 角 的 智能 按钮 ,在 智能 菜单 中 选择 [启用 删除 】 复 
选 框 ,就 可 以 了 。 

6) 启用 选择 内 容 

其 功能 是 为 当前 GridView 添加 一 个 选择 列 ,如果 单 击 选择 列 中 链接 【选择 】, 则 会 选中 
当前 记录 ,并 启动 运行 此 GridView 的 SelectedIndexChanged 方法 ,而 且 把 选中 的 记录 的 主 
键 值 记载 到 属性 SelectedValue 中 。 

具体 操作 时 , 单 击 GridView 对 象 右上 角 的 智能 按钮 ,在 智能 菜单 中 选择 【启用 选择 内 
容 ] 复 选 框 ,就 能 够 添加 “选择 ” 列 。 

3. GridView 的 列 编辑 

单 击 GridView 对 象 右上 角 的 智能 按钮 ,在 其 智能 菜单 中 选择 【编辑 列 】 则 会 打开 
【字段 ] 对 话 框 。 或 者 在 GridView 的 [属性 了 面板 中 单 击 Colomns 属性 的 小 按钮 ,也 会 打开 
【字段 ] 对 话 框 ,效果 如 图 6-9 所 示 。 

在 此 对 话 框 中 ,左上 角 【 可 用 字段 】 是 待 选 的 字段 ,左下 角 【 选 定 的 字段 为 已 选择 字段 。 
从 【 选 定 的 字段 】 中 选择 一 个 列 名 后 ,可 在 右 侧 的 【BoundField 属性 】 区 域 中 设置 该 列 的 相关 
属性 。 例 如 ,可 以 为 GridView 的 标题 设置 专用 的 中 文字 符 串 ,为 DataField 的 jie 字段 设置 
中 文字 段 名 “奖学金 ”。 

从 左上 角 的 【可 用 字段 区域 中 展开 CommandField, 可 为 当前 的 GridView 添加 “选择 ” 
列 “ 删 除 ? 列 和 “编辑 " 列 。 当 为 GridView 添加 了 “选择 ” 列 后 ,可 用 SelectedValue 返回 被 
选中 记录 的 主键 值 。 当 GridView 添加 了 “删除 ” 列 后 ,系统 自动 具备 了 删除 当前 记录 的 功 
能 ,不 需要 再 编写 代码 。 同 理 , 当 GridView 添加 了 “编辑 ” 列 后 ,系统 就 自动 具备 了 编辑 当 
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前 记录 的 功能 ,不 需 添加 程序 代码 。 不 过 ,被 编辑 的 记录 仅 以 一 行 的 文本 框 的 形态 出 现 , 虽 
然 其 格式 可 通过 调整 列 的 宽度 实现 修正 ,但 仍 不 适合 处 理 字段 较 多 的 记录 。 

注意 : 来 自 于 多 表 或 者 没有 主键 的 数据 源 无 法 直接 使 用 GridView 实施 编辑 ,删除 等 更 
新 操作 。 


图 6-9 对 GridView 设置 列 、 编 辑 列 


4. GridView 的 模板 列 

在 实际 的 项 目 开 发 中 ,GridView 提供 的 标准 列 常常 不 能 满足 要 求 , 例 如 为 GridView 添 
加 一 列 复 选 框 \ 直 接 修改 某 一列 数据 的 值 .开展 输入 数据 验证 等 。 对 于 这 些 任务 ,可 以 通过 
模板 列 实现 。 

1) 添加 GridView 模板 列 

在 如 图 6-9 所 示 的 对 话 框 中 ,如 果 从 左上 角 的 【可 用 字段 ] 区 域 中 选择 TemplatedField， 
可 为 GridView 添加 一 个 模板 列 。 选 中 新 添加 的 模板 列 , 在 右 侧 的 [TemplateField 属性 】 区 
域 中 为 HeaderText 属性 设置 值 ,说 明 模 板 列 的 含义 。 最 后 单 击 【 确 定 ] 按 钮 ,返回 到 
GridView 的 智能 菜单 。 

2) 编辑 GridView 模板 列 

在 GridView 的 智能 菜单 下 选择 [编辑 模板 】, 进 入 编 辑 模板 状态 ,如 图 6-10 所 示 。 


图 6-10 编辑 GridView 的 模板 列 
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选择 模板 ItemTemplate, 然 后 可 向 左 侧 的 “ItemTemplate” 区 域 中 添加 文本 框 、 复 选 框 
等 控件 。 

对 于 新 添加 的 模板 控件 ,也 有 一 个 智能 按钮 。 单 击 此 按钮 会 打开 智能 菜单 ,从 中 选择 
【编辑 DataBinding] 可 打开 DataBindings 对 话 框 。 此 时 可 把 模板 控件 绑 定 到 数据 源 中 的 某 
个 字段 上 ,如 图 6-11 所 示 。 


FMS): 
本 双向 数据 闭 定 中 
BN 加 
全 自 二 XSD: 
人 ah: 
BindCscore (ON 
BE [ We ] ms | 


图 6-11 为 GridView 模板 列 绑 定 数据 表 的 字段 


最 后 , 单 击 【结束 模板 编辑 】, 返 回 到 GridView 的 智能 菜单 。 

注意 ; 绑 定数 据 源 中 的 字段 可 使 用 关键 字 Eval 和 Bind。 其 中 Eval 关键 字 表 示 单 向 绑 
定 , 只 能 读 取 数据 表 中 的 数据 ,Bind 关键 字 表示 双向 绑 定 , 既 可 以 读 取 数 据 表 中 的 数据 ,也 
支持 把 数据 存 回 数据 库 。 

3) 获取 模板 列 中 的 数据 

要 获取 模板 列 中 控件 的 数据 ,可 以 使 用 以 下 语句 : 


GridView 对 象 名 .Rows[ 行 号 ].FindControl(" 模 板 控件 名 ") as 控件 类 型 ; 


例如 ,在 GridView 对 象 gvXsb 中 有 一 个 模板 列 , 模 板 列 中 包含 一 个 TextBox 控件 , 控 
件 名 称 为 txt。 如 果 需 要 输出 GridView 对 象 所 有 行 的 模板 列 的 值 ,使 用 的 C 代码 如 下 : 


foreach(GridViewRow gvr in gvXsb.Rows) { 
TextBox tt = gvr.FindControl("txt") as TextBox; 
Response. Write(tt. Text); 

| 


5. 获取 GridView 数据 的 常用 方法 
假设 存在 GridView 对 象 gvXsb, 要 获取 其 中 的 数据 ,主要 有 以 下 方法 。 
(1) 获取 GridView 中 的 指定 行 


GridViewRow gvr = gvXsb. Rows[ 行 号 ]; 
(2) 获取 GridView 指定 行列 的 数据 


String xx = gvr. Cells[ 列 号 ]. Text; // 从 已 经 得 到 的 Gridview 行 gvr 中 获取 
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String xx = gvXsb. Rows[ 行 号 ].Cells[ 列 号 ].Text; // 直 接 从 GridView 中 获取 ; 
(3) 获取 当前 选 定 行 的 序号 
int gvno = gvXsb. SelectedIndex; 
(4) 获取 选中 行 的 主键 之 值 
< 类 型 名 > xx = gvXsb. SelectedValue; 
或 者 : 
String id = gvXsb. DataKeys[ gvXsb. SelectedIndex]. Value. ToString( ); 


本 命令 仅 作用 于 与 “选择 ?相关 的 方法 中 。 
(5) 获取 当前 行 及 其 信息 
下 面 以 事件 对 应 方法 的 参数 e 作为 基准 ,利用 。. RowIndex 作为 当前 行 的 序号 。 


String xx = gvXsb. Rows[e.RowIndex]. Cells[ 列 号 ]. Text; 
// 获 取 当 前 行 指定 列 的 数据 ; 


或 者 


GridViewRow gvr = gvXsb. Rows[e. RowIndex]; 
// 获 取 当 前 行 的 信息 . 


本 命令 可 作用 于 与 删除 、 更 新 操作 相关 的 方法 中 。 


6.3.2 ”FormView 控件 


FormView 控件 在 一 页 中 仅 显 示 一 条 记录 ,可 通过 翻 页 显示 其 他 记录 的 控件 。 与 
DetailsView 不 同 的 是 ; FormView 控件 除了 具有 显示 记录 的 功能 外 ,还 能 编辑 ,删除 和 新 建 
记录 ,而 且 可 以 通过 模板 重新 排列 各 字段 在 页 面 中 的 布局 。 


1. FormView 控件 的 外 观 和 
一 个 FormView 控件 的 外 观 如 图 6-12 所 示 。 从 任 一 一 一 一 一 
图 6-12 可 知 , 它 具有 以 下 特点 ， 区 二 
。 每 个 页 面 显 示 一 条 记录 的 信息 ,每 个 字段 在 页 面 en 
中 占据 一 行 的 空间 。 ES 
。 底部 具有 【编辑 】 工 删除 和 【新 建 】 三 个 按钮 , 支 i a 
持 开发 者 利用 FormView 对 当前 记录 进行 操作 。 Be 
如 果 其 属性 AllowPaging 设置 为 true, 会 在 页 面 底 | a 


部 显示 出 页 码 ,可 利用 页 码 进行 记录 切换 , 跳 转 到 其 他 图 612 FormvView 对 象 的 浏览 视图 
记录 上 。 

对 FormView 控件 的 关键 设计 就 是 对 页 面 布局 (修改 模板 ) 和 绑 定数 据 源 。 如 果 要 通过 
FormView 更 新 数据 表 内 容 , 那 么 被 绑 定 的 数据 源 中 必须 包含 数据 表 的 主键 ,而 且 数 据 表 江 
足 更 新 条 件 。 
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2. FormView 控件 的 主要 属性 与 方法 
FormView 控件 的 主要 属性 与 方法 如 表 6-3 所 示 。 


表 6-3 FormView 控件 的 主要 属性 与 方法 


属性 /方法 取 值 说 有 明 
DataSourceID 数据 源 标志 设置 GridView 的 数据 源 
DataKeyNames 字段 名 指明 数据 表 的 主键 字段 
PAGE true 允许 自 动 分 页 

false 不 允许 自动 分 页 

ReadOnly 查询 方式 ; 默认 值 就 是 ReadOnly 
DefaultMode Insert 插入 模式 

Edit 编辑 模式 
PagelIndexChanging 事件 对 应 被 翻 页 时 要 执行 的 方法 
PageIndexChanged 事件 对 应 被 翻 页 后 要 执行 的 方法 
ItemDeleting 事件 对 应 于 字段 被 删除 时 要 执行 的 方法 
ItemDeleted 事件 对 应 于 字段 被 删除 后 要 执行 的 方法 
ItemUpdating 事件 对 应 于 字段 被 修改 时 要 执行 的 方法 
ItemUpdated 事件 对 应 于 字段 被 修改 后 要 执行 的 方法 


3. FormView 模板 的 管理 

对 FormView 模板 的 管理 是 实施 页 面 布局 的 关键 ,其 基本 步骤 如 下 。 

(1) 单 击 FormView 对 象 的 智能 按钮 ,打开 其 智能 菜单 ,从 中 选择 [编辑 模板 】 ,打开 其 
模板 编辑 方式 ,如 图 6-13 所 示 。 

(2) 从 智能 菜单 中 选择 HeaderTemplate( 页 眉 ) 模 板 , 进 入 HeaderTemplate 模板 模式 。 
直接 输入 页 眉 , 例 如 “学 生 情 况 卡片 ”。 然 后 可 利用 系统 菜单 设置 字体 、 字 形 和 字号 ,以 及 对 
齐 方式 ,其 默认 视图 如 图 6-14 所 示 。 


FomTestaspx | FormViewaspx | 起 mn| 
CC - 


| sbrorm - hemTemplate le 


图 6-13 编辑 FormView 的 智能 菜单 6-14 FormView 对 象 的 默认 视图 


(3) 从 智能 菜单 中 选择 ItemTemplate( 数 据 项 ) 模 板 , 进 入 ItemTemplate 模板 模式 。 此 
时 可 为 此 模板 插入 一 个 HTML 方式 的 表格 ,然后 把 有 关 数 据 项 移动 到 表格 中 。 

总 之 ,利用 表格 可 控制 各 个 控件 的 摆 放 位 置 ,使 之 达到 较为 理想 的 效果 ,如 图 6-15 
所 示 。 
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(4) 从 智能 菜单 中 选择 InsertItemTemplate( 插 入 ) 模 板 , 进 入 InsertItemTemplate 模板 
模式 。 接 着 为 插入 界面 重新 摆 放 控件 ,使 之 协调 。 | 

(5) 同 理 ,也 可 以 直接 修改 EditltemTemplate | Gaertn 
(编辑 ) 模 板 ,进入 EditItemTemplate 模板 设计 和 | 
模式 ,对 编辑 界面 重新 排列 、 摆 放 控 件 ,使 之 |||， Beel 。 站 各， Pentabel] 性 Ia 
协调 。 

(6) 最 后 , 单 击 智能 菜单 中 的 【结束 模板 编 
辑 】, 回 到 FormView 的 设计 视图 。 

注意 ; 在 FormView 默认 的 Insertltem- (一 
Template 和 EditltemTemplate 模板 中 ,所 有 数 6-15 改变 FormView 对 象 默认 布局 
据 项 对 应 的 交互 框 都 是 文本 框 。 在 实际 编辑 模 
板 的 过 程 中 ,开发 者 可 以 把 文本 框 删除 ,替换 为 下 拉 式 列表 框 或 其 他 控件 ,从 而 增强 系统 的 
易 用 性 。 但 需要 注意 的 是 ,在 把 文本 框 删除 并 以 新 的 控件 取代 原文 本 框 后 ,应 该 重新 绑 定 数 
据 源 (要 双向 绑 定 ) ,以 保证 新 控件 能 够 与 数据 库 实现 双向 通信 。 

绑 定 数据 源 的 方法 是 : 先 选 定 新 建 的 控件 ,通过 其 右上 角 的 智能 按钮 打开 智能 菜单 ,从 
中 选择 [编辑 DataBindings】, 打开 绑 定数 据 源 的 对 话 框 ,如 图 6-16 所 示 。 


回 号 示 所 有 尾 性 (A) 


图 6-16 为 FormView 对 象 绑 定数 据 源 
通过 此 对 话 框 ,把 新 控件 与 数据 源 的 字段 名 绑 定 在 一 起 。 关 键 词 Bind 表示 双向 绑 定 ， 
而 Eval 表示 单 向 绑 定 。 
6.4 基于 SqlDataSource 的 查询 示例 


6.4.1 简单 查询 程序 


1. 以 GridView 分 页 显示 记录 
1) 案例 要 求 
以 列表 方式 输出 学 生 表 的 全 部 内 容 ,结果 以 分 页 方式 显示 ,每 页 5 条 记录 。 
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2) 实现 过 程 

(1) 新 建 项 目 DataSourceTest, 系统 自动 新 增 Web 窗 体 Default, 并 处 于 其 【设计 ] 视 
图 下 。 

(2) 打开 “服务 器 资源 管理 器 ”, 打 开 前 面 已 经 创建 好 的 数据 连接 XSGL. DBO。 

(3) 在 “服务 器 资源 管理 器 ”中 展开 “数据 连接 ”, 找 到 数据 表 “ 学 生 表 ”。 

(4) 以 鼠标 拖 动 数据 表 “ 学 生 表 ”到 Web 窗 体 中 ,到 适当 位 置 松 开 鼠 标 。 系 统 会 自动 在 
Web 窗 体 中 创建 两 个 对 象 : SqlDataSourcel 和 GridView1, 得 到 如 图 6-2 所 示 的 对 话 框 。 
如 果 此 时 预览 此 Web 窗 体 ,会 发 现 以 下 两 个 不 足 : 目前 的 输出 没有 分 页 功能 ; @ 所 有 字 
段 的 标题 都 是 拼音 字母 形式 ,不 便于 理解 。 

(5) 单 击 GridViewl 控件 右上 角 的 智能 按钮 ,打开 智能 菜单 ,从 中 选择 【自动 套用 格 
式 】, 则 打开 一 个 对 话 框 ,从 中 选择 一 种 较为 理想 的 架构 。 

(6) 单 击 GridView 右上 角 的 智能 按钮 ,打开 智能 菜单 ,从 中 选择 【编辑 列 】, 则 打开 【 字 
段 ] 对 话 框 ,如 图 6-17 所 示 。 


6-17 为 GridView 设 定 列 、 编 辑 列 


(7) 从 【 选 定 的 字段 】 中 选择 *“xh”, 在 右边 的 【BoundField 属性 】 中 修改 其 HeaderText 
值 为 “学 号 ”, 即 可 为 字段 xh 赋予 一 个 中 文 “学 号 ”作为 输出 的 标题 。 

(8) 同 理 , 修 改 其 他 字段 的 标题 。 最 后 单 击 【 确 定 ] 按 钮 确认 修改 ,返回 到 窗 体 的 [设计 】 
视图 下 。 此 时 系统 显示 界面 如 图 6-18 所 示 , 所 有 字段 的 标题 已 经 成 为 中 文 模式 。 

(9) 在 [设计 了 视图 下 , 单 击 GridView 的 智能 菜单 ,从 中 选中 [启用 分 页 】。 预 览 此 Web 
窗 体 ,会 发 现 此 页 面 已 经 具有 分 页 功能 ,但 每 页 默认 记录 数 是 10 个 。 

(10) 在 【设计 视图 下 , 选 定 GridView, 然 后 在 其 [属性 ] 面 板 中 找到 PageSize 属性 ,把 
其 值 修 改 为 5。 或 者 转 到 C# 设 计 模式 下 ,在 Page_Load 函数 中 增加 一 行 : 


GridView]. PageSize = 5; 


(11) 最 后 ,预览 此 Web 窗 体 ,检查 效果 。 
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6-18 以 GridView 显示 学 生 表 信息 


2. 数据 查询 并 分 页 显示 

1) 案例 要 求 

从 已 经 存在 的 “数据 连接 ”中 ,按照 学 生 所 在 单位 查询 学 生 , 要 求 结 果 以 列表 方式 输出 ， 
并 以 分 页 方式 显示 出 来 。 

2) 实现 过 程 

由 于 学 校 中 的 单位 已 经 基本 固定 ,因此 可 利用 下 拉 式 列表 框 提供 一 个 选取 单位 名 称 的 
对 象 。 在 用 户 选 定单 位 后 ,由 GridView 对 象 负责 显示 出 该 单位 的 全 体 学 生 。 因 此 ,这 个 程 
序 中 GridView 的 数据 来 源 由 下 拉 式 列表 框 控制 , 即 需要 建立 依托 于 下 拉 式 列表 框 控件 的 
SqlDataSource, 以 便 为 GridView 提供 可 用 的 数据 源 。 

(1) 新 增 窗 体 并 布局 

在 项 目 DataSourceTest 中 新 增 Web 窗 体 sjcx, 并 处 于 其 [设计 了 视图 下 。 通 过 【工具 箱 】 
的 [HTML)] 栏 目 向 窗 体 中 添加 一 个 Table 对 象 ,适当 调整 单元 格 的 宽度 和 高 度 ,完成 页 面 
的 局 部 布局 。 

(2) 创建 所 需 的 控件 

在 Web 窗 体 的 [设计 了 视图 中 向 窗 体 的 适当 位 置 输入 文字 “请 选择 学 生 单位 :”, 并 在 后 
边 添加 一 个 “标准 ”控件 DropDownList ,修改 其 ID 为 ddIDw。 然 后 再 添加 一 个 “标准 ”控件 
Button ,修改 其 ID 为 btnDw, 其 Text 属性 为 “开始 查找 ”。 

(3) 添加 SqlDataSource 和 GridView 

打开 【服务 器 资源 管理 器 】 面 板 ,打开 前 面 已 经 创建 好 的 数据 连接 XSGL. DBO。 展 开 
“数据 连接 ”, 找 到 数据 表 “ 学 生 表 ”, 以 鼠标 拖 动 数 据 表 “ 学 生 表 ” 到 Web 窗 体 中 ,到 适当 位 置 
松 开 鼠标 。 系 统 会 自动 在 Web 窗 体 中 创建 两 个 对 象 SqlDataSourcel 和 GridView1 ,分别 修 
改 这 两 个 对 象 的 名 字 为 dsXs、gvXs, 结 果 如 图 6-19 所 示 。 
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请 选择 学 生 单位 ， [ 必 耳 司 到 本 
a 


T 


= i csdate dwei zhy' 汪 Plane | 


缚 定 阔 人 ee 
人 定数 据 绕 定 救 据 绊 定 救 所 
人 


SqlDataSource - dsXs 


图 6-19 新 增 SqlDataSource、GridView 等 对 象 的 效果 图 


(4) 为 DropDownList 对 象 ddlDw 的 选项 绑 定数 据 源 

首先 ,创建 输出 单位 名 称 的 数据 源 dsDw。 把 数据 源 dsXs 复制 一 份 , 命 名 为 dsDw。 然 
后 选择 数据 源 dsDw, 对 其 属性 SelectQuery int rainy gma 
改 其 SQL 语句 ,使 之 成 为 “select distinct dwei from 学 生 表 order by dwei;”。 补 充 说 明 : 
此 SQL 语句 中 的 distinct 表示 单位 名 称 唯 一 输出 ， 
不 保留 重复 的 单位 名 ,order by dwei 子 句 表示 按照 
单位 名 称 升 序 输出 单位 名 称 。 

其 次 ,为 控件 ddlDw 绑 定数 据 源 。 选 定 控件 
ddlDw, 单 击 其 右上 角 智 能 按钮 ,在 智能 菜单 中 选 
择 [选择 数据 源 】, 在 随后 弹出 的 [数据 源 配 置 向 导 】 
对 话 框 中 进行 如 图 6-20 所 示 配 置 。 

通过 以 上 配置 ,使 下 拉 式 列表 框 以 数据 源 
dsDw 的 dwei 字段 内 容 作为 其 选项 。 

(5) 优化 GridView 对 象 

修改 GridView 对 象 gvXs 的 DataSource 属性 
的 值 为 “dsXs”。 单 击 对 象 gvXs 右上 角 的 智能 按 图 6-20 为 ddlDw 绑 定数 据 源 ， 

钮 ,打开 智能 菜单 ,选择 [自动 套用 格式 〗, 然 后 调整 设置 选项 字段 
GridView 的 显示 格式 。 

选择 “编辑 列 ”, 改 变 此 GridView 的 标题 行 ,选择 “出 生日 期 (csdate)” 列 ,设置 其 
DataFormatString 为 {0:d)。 

(6) 设置 ddlDw 对 gvXs 的 控制 

首先 ,选择 数据 源 dsXs, 在 [属性] 面板 中 找到 SelectQuery 属性 ,通过 单 击 其 右 侧 的 小 
按钮 打开 [命令 和 参数 编辑 器 ] 对 话 框 ,如 图 6-21 所 示 。 

其 次 , 单 击 左下 角 的 按钮 [添加 参数 】, 为 本 对 象 添加 参数 danwei, 并 通过 右 部 的 【参数 
源 ] 下 拉 列 表 框 选择 Control, 表 示 以 控件 作为 参数 源 。 最 后 选择 ddIDw 作为 ControlID 的 
值 。 即 设置 了 窗 体 中 的 对 象 ddlDw 的 值 作为 参数 danwei 的 值 。 

最 后 , 单 击 右 上 部 的 [查询 生成 器 ] 按 钮 ,打开 “查询 生成 器 *。 如 图 6-22 所 示 , 为 dwei 
(单位 ) 行 的 第 选 器 设置 参数 “@danwei”。 

经 过 上 述 操作 ,就 把 ddIDw 控件 和 gvXs 控件 关联 了 起 来 。 
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SELECT 人 SC: 
SELECT gdhl Boml [xbl, [csdatel [dweil, [zhyel, [phonel Wie] FROM [ 尝 生 秦 ] 


学 生 表 网 | 
DW) a 
已 
lm 


列 
dwei 


ze 


‘ 
SELECT xh, xm, xb, csdate, dwei, zhye, phone, jje 
«4 or My 


6-22 ”以 查询 生成 器 设置 SQL 语句 一 一 绑 定 筛选 器 的 值 


(7) 为 按钮 btnDw 的 Click 事件 编程 

双击 按钮 btnDw, 系 统 进 入 到 sjcx. aspx. cs 的 编程 模式 下 ,为 btnDw_Click 事件 添加 代 
码 “gvXs. DataBind();”。 通 过 此 语句 ,保证 用 户 在 下 拉 式 列表 框 选 定 了 单位 后 ,下 面 的 
GridView 中 能 够 正确 地 显示 出 查询 结果 。 

3. 以 FormView 显示 单个 指定 记录 

如 果 需 要 以 FormView 显示 单个 指定 记录 ,可 以 设计 为 按照 学 号 查找 某 个 学 生 并 显示 
出 来 。 因 此 可 以 首先 定义 一 个 文本 框 TextBox, 由 这 个 文本 框 控制 FormView 中 要 显示 的 
那 条 记录 。 具 体操 作 过 程 如 下 。 

(1) 新 增 窗 体 并 布局 

在 项 目 DataBaseTest 中 新 增 窗 体 FormView。 在 其 【设计 】 视 图 下 ,通过 【工具 箱 ] 的 
HTML 栏目 向 窗 体 中 添加 一 个 Table 对 象 ,适当 调整 单元 格 的 数量 、 宽 度 和 高 度 , 使 页 面 适 
当 布 局 。 
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(2) 创建 窗 体 所 需 的 控件 

在 Web 窗 体 的 【设计 了 视图 状态 ,向 窗 体 的 适当 位 置 输入 文字 “请 输入 学 生 学 号 :”, 并 在 
后 边 添加 一 个 “标准 ”控件 TextBox', 修 改 其 ID 为 xsxh。 然 后 再 添加 一 个 “标准 ?控件 
Button ,修改 其 ID 为 btnXs, 其 Text 属性 为 “查找 ”。 

(3) 添加 SqlDataSource 和 FormView 

首先 ,打开 [服务 器 资源 管理 器 面板 ,从 “数据 连接 ”的 XSGL. DBO 下 找到 “学 生 表 ”， 
以 鼠标 拖 动 “ 学 生 表 ”到 Web 窗 体 底部 。 系 统 会 自动 在 Web 窗 体 中 创建 两 个 对 象 : 
SqlDataSourcel 和 GridView1。 修 改 SqlDataSourcel 的 名 字 为 dsXsb, 并 删除 对 象 
GridView1l 。 

然后 , 从 【工具 箱 】 的 【数据 栏目 中 拖 动 
FormView 控件 到 Web 窗 体 的 适当 位 置 ,创建 一 个 
FormViewl 对 象 。 利 用 [属性 面板 修改 其 ID 属性 
为 xsForm, 设 置 这 个 对 象 的 DataSource 属性 的 值 
为 dsXsb( 前 面 创建 的 数据 源 对 象 名 ) ,设计 界面 如 
图 6-23 所 示 。 

(4) 调整 并 优化 xsForm 对 象 

单 击 xsForm 对 象 右上 角 的 智能 按钮 打开 智能 


请 输入 学 生 学 号 ， | 


EEC 
学 生 信息 卡片 


菜单 ,选择 【编辑 模板 】, 进 入 模板 编辑 模式 。 图 6-23 针对 学 生 表 的 FormView 
首先 选择 HeaderTemplate, 为 此 区 域 加 入 文字 初步 效果 图 


“学 生 信 息 卡 片 ”, 并 可 设置 字形 、 字 号 和 位 置 。 

接着 选择 ItemTemplate, 编 辑 字段 项 目 工作 区 。 可 为 此 工作 区 加 入 一 个 HTML 方式 
的 Table 对 象 ,适当 调整 Table 中 单元 格 的 数量 、 大 小 ,然后 把 FormView 中 的 字段 移动 到 
Table 的 单元 格 中 ,使 各 个 字段 的 摆 放 位 置 恰当 ,合理 布局 。 

删除 底部 的 按钮 [编辑 ]【 新 建 和 【删除 ]。 设 置 csdate 字段 的 格式 为 {10:d)} 。 

(5) 建立 文本 框 xsxh 对 xsForm 的 控制 

文本 框 xsxh 对 xsForm 的 控制 应 该 通过 修改 xsForm 的 数据 源 来 实现 , 即 找到 数据 源 
对 象 dsXsb, 找 到 其 属性 SelectQuery, 然 后 通过 单 击 其 右 侧 的 小 按钮 启动 [命令 和 参数 编辑 
器 对话 框 。 在 【命令 和 参数 编辑 器 〗 对 话 框 中 ,首先 【添加 参数 ]stuxh, 设 置 其 参数 源 为 
“Control”, 对 应 的 控件 是 “xsxh”。 然 后 单 击 【 查 询 生成 器 】〗, 打 开 【 查 询 生成 器 】 对 话 框 ,把 参 
数 *@stuxh” 添 加 到 xh 行 的 筛选 器 中 。 使 控件 xsxh 能 够 控制 xsForm 的 显示 内 容 。 

经 过 上 述 操作 ,就 把 xsxh 控件 和 xsForm 控件 关联 了 起 来 。 

(6) 为 按钮 btnXs 的 Click 事件 编程 

双击 按钮 btnXs, 系 统 进 入 到 formView. aspx. cs 的 编程 模式 下 ,为 btnXs_Click 事件 添 
加 代码 :“xsForm. DataBind();” 通 过 此 语句 ,保证 用 户 在 用 下 拉 式 列表 框 选 定 了 单位 后 ,在 
下 面 的 GridView 中 就 能 够 正确 地 显示 出 查询 结果 。 


6.4.2 级 联 程序 


在 动态 网 站 开发 中 ,设计 级 联 程序 也 是 一 种 常见 的 要 求 。 所 谓 级 联 程序 ,就 是 一 个 控件 
的 选 定 值 能 够 控制 另外 一 个 控件 中 的 显示 数据 。 常 见 的 模式 有 两 个 : GridView 程序 的 级 
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联 , 一 个 GridView 程序 与 一 个 FormView 程序 的 级 联 。 
1. 选 定 学 生 并 以 FormView 显示 其 详细 信息 
制作 如 图 6-24 所 示 的 程序 : 当 从 左 侧 的 GridView 中 选 定 一 个 学 生 后 ,会 在 右 侧 的 
FormView 中 显示 出 此 学 生 的 详细 信息 。 
1) 设计 思路 
按照 图 6-24 的 示例 ,需要 在 左 侧 放置 一 个 
GridView 控件 ,此 控件 只 显示 学 生 表 的 3 列 数 | Bi ints 


S014 李 大 军 男 选择 学 号 : S014 。” 姓名: 李 大 军 
据 并 包含 一 个 “选取 ” 列 。 右 侧 放 置 一 个 | so1s 纪 继 平 女 选 笃 性 别 : 男 ” 生日 


和 w 单位 ， 教 育 系 专 业 ， 

FormView 控件 ,能 够 显示 出 一 条 记录 的 所 有 数 | so7 礁 志 远 男 选择 电话 ， 奖学金 : 
据 项 的 内 容 。 这 两 个 控件 应 该 依托 于 两 个 
SqlDataSource 控件 。 由 于 当 GridView 中 的 选 ”图 6-24 学 生 查询 级 联 程序 的 最 终 效果 图 
定数 据 发 生变 化 时 , FormView 中 的 记录 自动 变 
化 。 因 此 ,FormView 的 数据 源 控件 要 受到 GridView 控件 的 约束 。 

2) 设计 过 程 

(1) 新 建 窗 体 并 布局 

新 建 一 个 Web 窗 体 ,命名 为 showDetail。 然 后 ,在 其 [设计 3 视图 下 ,插入 一 个 表格 , 进 
行 适当 布局 。 

(2) 添加 控件 并 初步 设置 

首先 ,向 窗 体 中 的 单元 格 中 添加 标题 文字 “学 生 信息 检索 ”, 并 适当 设置 文字 的 外 观 。 

其 次 ,添加 一 个 DropDownList 控件 ,修改 其 ID 为 ddIDw; 再 添加 一 个 Button 控件 , 修 
改 ID 为 btnDw, 修 改 其 Text 属性 为 “选择 单位 ”。 

第 三 ,从 [服务 器 资源 管理 器 面板 中 把 数据 连接 “XSGL. DBO” 下 的 表 “ 学 生 表 ” 拖 动 到 
窗 体 的 左 侧 位 置 ,系统 自动 创建 两 个 对 象 : GridViewl 和 SqlDataSourcel 。 修 改 这 两 个 对 
象 的 ID 为 gvXsb 和 dsXsb, 并 且 设 置 gvXsb 的 DataSourceID 属性 为 dsXsb, 绑 定 新 的 数 
据 源 。 

第 四 ,从 【服务 器 资源 管理 器 面板 中 把 数据 连接 “XSGL. DBO” 下 的 表 “ 学 生 表 ” 拖 动 到 
窗 体 的 右 侧 部 分 ,系统 自动 创建 对 象 GridView2 和 SqlDataSource2。 修 改 SqlDataSource2 
对 象 的 ID 为 dsForm 。 

最 后 ,删除 多 余 的 对 象 GridView2, 再 从 工具 箱 】 的 【数据 ] 栏 目 中 拖 动 一 个 FormView 
对 象 到 窗 体 的 右 侧 , 系 统 将 创建 一 个 名 字 为 FormViewl 的 对 象 , 最 终结 果 如 图 6-25 所 示 。 

(3) 配置 GridView 对 象 

选中 控件 gvXsb, 启 动 其 右上 角 的 智能 菜单 ,选择 [自动 套用 格式 】, 先 为 本 GridView 选 
择 比 较 理 想 的 格式 ; 然后 把 【启用 选 定 内 容 】 复 选 框 设置 为 有 效 ,使 之 出 现 * 选 取 ” 列 。 最 后 
再 选择 [编辑 列 】 ,把 每 列 的 “HeaderText” 更 新 为 中 文 ,并 删除 多 余 的 列 , 只 保留 “学 号 ”“ 姓 
名 ”“ 性 别 " 和 “选取 ” 列 。 

(4) 配置 FormView 对 象 

首先 ,选中 SqlDataSource 控件 dsForm, 从 【属性 】 面 板 中 找到 其 属性 “SelectQuery”。 
通过 “SelectQuery” 右 侧 的 小 按钮 打开 【命令 和 参数 编辑 器 ] 对 话 框 。 

其 次 ,为 此 控件 添加 参数 xh, 而 且 让 参数 xh 绑 定 到 控件 gvXsb, 如 图 6-26 所 示 。 


学 生 信 息 检索 
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showDetailaspx" [EE 把 到 = 
学 生 信 息 检索 

[sh xm ab | csdate ldweizhye phonejlie| 

abcabcabc ea abc abc abc 0 


人 ODS we bel se | Sqlpatasource - sqlDataSource2 


| 
20112/5| 
0:00:00 


| FormView - FormViewl 
be abe abe 2011213 ,be abe abc | 2 | 二 “第 和 模板 ”任务 未 入 和 模板 内 容 . 
0:00:00 
| 
| 
| 


abcabc abe abe abc abc 4 


和 多 也 [5 Ea 
SELECT 命 S(G): 
SELECT [xh], fml [xb] [csdate], {dweil, [zhye], [phonel, 而 e] FROM [等 生 于 ] where xh=@xh 
| [aasaao | 
2 。 
名 称 全 | | [centol ~ 
轴 gyXsb.SelectedValue | ControllD: 
| lb 
| 
DefaultValue: 
| 
二 ho) | 
mm 


6-26 设置 FormView 数据 源 的 【命令 和 参数 编辑 器 ] 对 话 框 


最 后 , 单 击 FormViewl 的 智能 按钮 ,启动 智能 菜单 。 首 先 ,【 选 择 数据 源 ] 设 置 为 
dsForm。 然 后 选择 【编辑 模板 】, 进 入 到 模板 编辑 状态 。 可 先 编辑 【HeaderTemplate】, 为 页 
面 设置 页 眉 ,输入 文本 “学 生 详细 信息 ”; 再 编辑 [ItemTemplate] 模 板 ,删除 底部 的 【编辑 】、 
【新 建 ] 和 【删除 按钮; 最 后 ,对 数据 表 的 数据 项 重新 排列 、 摆 放 , 使 页 面 协调 。 在 这 个 过 程 
中 ,可 以 借助 Table 布局 工具 。 

(5) 为 GridView 对 象 的 gvXsb 选择 事件 编写 C# 代码 

回 到 【设计 了 视图 ,双击 GridView 控件 gvXsb, 进 入 到 C# 编 程 状态 。 在 showDetail. aspx. cs 
下 ,为 gvXsb_SelectedIndexChanged 添加 如 下 代码 : 


FormView1. DataBind( ); 


(6) 保存 所 有 程序 ,用 浏览 器 预览 效果 

2. 显示 选 定 学 生 的 成 绩 单 

1) 案例 要 求 

制作 如 图 6-27 所 示 的 程序 ,当选 定 学 生 单位 后 ,在 上 面 的 GridView 中 列 出 学 生 表 的 关 
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键 信息 ; 当 用 户 单 击 上 面 一 个 GridView 中 的 学 生 后 ,将 在 下 面 一 个 GridView 中 列 出 该 学 
生 选 修 的 课程 的 课程 号 .课程 名 学分、 成 绩 和 考试 时 间 。 


学 生成 绩 管 理 系统 
请 选择 学 生 单位 ， 二 回 医 志 2 到 | 
学 号 | 姓名 | 性 别 | 生日 | 单位 | 专业 | 联系 电话 
S001 张 萍 志 男 ”1989/12/1 物理 系 物理 学 687091234 1000 ”选择 
S003 刘 明 ” 女 1990/4/12 物理 系 物理 学 698721212 800 ”选择 


S007 套 垦 媛 女 物理 系 选择 
S009 赵 大 云 男 物理 系 选择 
学 生 的 成 绩 单 ， 

1 KO0l 力学 4 28 2010/12/12 

2 Ko02 热学 3 832 201U110 


图 6-27 两 个 GridView 实施 级 联 的 最 终 效果 图 


2) 设计 思路 

按照 图 6-27 的 样式 ,创建 一 个 下 拉 式 列表 框 两 个 GridView。 以 下 拉 式 列表 框 的 选项 控 
制 上 面 GridView 的 显示 记录 ,用 上 面 GridView 的 选中 记录 控制 下 面 GridView 的 显示 信息 。 

为 了 控制 下 拉 式 列表 、 第 一 个 GridView 和 第 二 个 GridView, 分 别 需 要 三 个 SqlDataSource 
控件 。 服 务 于 下 拉 式 列表 框 的 数据 源 控件 仅 需 唯一 性 地 输出 单位 信息 ,服务 于 第 一 个 
GridView 的 数据 源 控件 仅 需 要 学 生 表 的 3 一 4 个 关键 字段 ,服务 于 第 二 个 GridView 的 数据 
源 控件 需要 课程 表 和 成 绩 表 的 连接 ,需要 包含 两 张 数据 表 的 综合 信息 。 

3) 设计 过 程 

(1) 新 建 窗 体 并 布局 

新 建 一 个 Web 窗 体 ,命名 为 showCjd。 在 其 【设计 】 视 图 下 ,插入 一 个 表格 ,进行 适当 
布局 。 

(2) 添加 控件 并 初步 设置 

向 窗 体 中 的 单元 格 中 添加 标题 文字 “学 生成 绩 管理 系统 ”“ 请 选择 学 生 单 位 :”“ 学 生 的 
成 绩 单 :,”, 并 适当 设置 文字 的 外 观 。 

然后 添加 一 个 DropDownList 控件 ,修改 其 ID 为 ddIDw; 再 添加 一 个 Button 控件 , 修 
改 ID 为 btnDw, 修 改 其 Text 属性 为 “选择 单位 ”。 

从 [服务 器 资源 管理 器 ] 面 板 中 把 数据 连接 “XSGL. DBO” 下 的 表 “ 学 生 表 ” 拖 动 到 窗 体 
的 适当 位 置 , 系 统 自动 创建 两 个 对 象 GridViewl 和 SqlDataSourcel。 修 改 这 两 个 对 象 的 
ID 为 gvXsb 和 dsXsb, 并 且 设 置 gvXsb 的 DataSourceID 属性 为 dsXsb, 绑 定 新 的 数据 源 。 

同 理 , 从 【服务 器 资源 管理 器 面板 中 把 数据 连接 “XSGL. DBO” 下 的 表 “ 成 绩 表 ” 拖 动 到 
窗 体 的 适当 位 置 , 修 改 这 两 个 对 象 的 人 D 为 gvCib 和 dsCib, 并 且 设 置 gvCib 的 DataSourceID 属 
性 为 dsCib。 绑 定 新 的 数据 源 , 如 图 6-28 所 示 。 

(3) 配置 DropDownList 控件 

把 SqlDataSource 控件 dsXsb 复制 一 份 , 重 命名 为 dssDw。 利 用 [属性 ] 面 板 修改 新 控件 
dsDw 的 SelectQuery 属性 ,在 [命令 和 参数 编辑 器 ] 对 话 框 中 进行 如 图 6-29 所 示 的 设置 ,使 
此 数据 源 仅 输出 单位 名 称 ,而 且 能 够 过 滤 掉 重复 的 单位 名 称 ,并 按照 单位 名 称 升序 输出 。 
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请 选择 学 生 单位 ， [E73 | 庆 择 单位 
而 xm 动 csdate dweizhyephonejlie 

abcabc abc 2011/2/5 00000abc abc abc 0 

abc abc abc 2011/2/5 00000abc abc abc 1 

abc abe abe 2011/2/5 0:00.00abe abe abe 2 

abc abc abc 2011/2/5 0:00:00abe abc abc 3 

abc abc abc 2011/2/5 00000abc abe abe 4 


0 abcabc0 2011/2/5 00000| 
1 abcabc 0.1 201125 00000| 
2 abcabc 02 2011/2/5 00000 
3 abcabc03 2011/2/5 00000 
4 abcabc 0.4 2011/2/5 00000| 


SELECT 命令 @: 


LECT distinct [dwei] FROM [学 生 胡 ] order by [dwei] 


参数 (ED): 
名 称 


6-29 数据 源 dsDw 的 Select 命令 配置 对 话 框 (对 单位 唯一 性 输出 ) 


选中 下 拉 式 列表 框 控 件 (ddIDw) ,打开 其 右上 角 的 智能 菜单 ,从 中 选择 【选择 数据 源 】, 
为 ddlDw 选择 数据 源 “dsDw”, 设 置 其 【显示 的 数据 字段 ] 为 “dwei”,【 值 的 数据 字段 ] 为 
“dwei”。 

(4) 配置 dsXsb, 使 gvXsb 受 ddlDw 的 控制 

选中 SqlDataSource 控件 dsXsb, 从 【属性 了 面板 中 找到 其 属性 “SelectQuery”。 通 过 
“SelectQuery” 右 侧 的 小 按钮 打开 【命令 和 参数 编辑 器 】 对 话 框 。 为 此 控件 添加 参数 
danwwei, 而 且 让 参数 danwei 绑 定 控件 ddIDw ,并且 利 用 【查询 生成 器 把 SQL 语句 设置 成 
“ 找 出 所 在 单位 等 于 参数 danwei 的 学 生 ” 的 信息 ,设置 界面 如 图 6-30 所 示 。 

通过 这 种 设置 ,就 建立 了 ddlDw 与 gvXsb 之 间 的 控制 关系 。 

(5) 配置 gvXsb, 使 之 优化 

选中 控件 gvXsb, 启 动 其 右上 角 的 智能 菜单 ,选择 [自动 套用 格式 】, 为 本 GridView 选择 
比较 理想 的 格式 ; 把 [启用 选 定 内 容 ] 复 选 框 设置 为 有 效 , 使 之 出 现 “ 选 择 ” 列 。 最 后 再 选择 
【编辑 列 】, 先 把 每 列 的 “HeaderText” 更 新 为 中 文 , 并 可 适当 地 删除 一 些 列 。 
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6-30 “为 第 一 个 GridView 绑 定 查询 参数 


(6) 配置 dsCjb, 使 之 包含 全 部 所 需 字段 ,并 受 控 于 gvXsb 的 选项 

选中 SqlDataSource 控件 dsCjb, 从 [属性] 面板 中 找到 其 属性 “SelectQuery”。 通 过 
“SelectQuery” 右 侧 的 小 按钮 打开 【命令 和 参数 编辑 器 ] 对 话 框 。 利 用 此 对 话 框 ,为 此 控件 添 
加 参数 xh, 而 且 让 参数 xh 绑 定 到 控件 gvXsb。 

利用 右上 部 的 [查询 生成 器 ] 按 钮 打开 [查询 生成 器 】〗。 首 先 , 右 击 上 部 区 域 , 从 弹出 菜单 
中 选择 [添加 表 】 ,把 “成 绩 表 ”“ 课 程 表 ” 添 加 到 [查询 生成 器 中。 由 于 这 三 张 表 已 经 创建 过 
外 键 联系 ,所 以 它们 自动 创建 了 连接 。 接 着 ,利用 中 部 的 [输出 ] 复 选 框 选择 要 输出 的 字段 
kch .kcm score xuefen .kstime。 最 后 ,在 “筛选 器 ? 列 的 xh 行 输入 筛选 条 件 “@xh”, 表 示 查 
找 “xh” 等 于 参数 “@xh” 值 的 学 生 的 成 绩 ,如 图 6-31 所 示 。 


0 /10 Ha | 国 


6-31 设置 从 多 表 查 询 数据 的 查询 生成 器 


(7) 修改 C# 程 序 
回 到 [设计 ] 视 图 ,双击 按钮 [选择 单位 】, 进 入 到 C# 编程 状态 。 在 showCjb. aspx. cs 
中 ,为 btnDw_Click 添加 代码 “gvXsb. DataBind();”。 
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再 次 回 到 [设计 ] 视 图 ,双击 GridView 控件 gvXsb, 进 入 到 C# 编 程 状态 。 在 showCjb. aspx cs 
下 ,为 gvXsb_SelectedIndexChanged 添加 代码 “gvCjb. DataBind() ;”。 
(8) 保存 所 有 程序 ,以 浏览 器 预览 效果 


6.5 基于 SqlDataSource 的 更 新 程序 的 实例 


6.5.1 简单 更 新 程序 


1. 以 FormView 实现 数据 输入 

1) 案例 要 求 

制作 如 图 6-32 所 示 的 程序 ,通过 FormView 向 “学 生 表 ”中 插入 记录 后 ,能 够 在 
GridView 中 显示 出 插入 的 结果 。 


学 生 信息 输入 界面 


已 注入 学 生 的 名 单 ， 


4 名 | 性别 | 生日 单位 专业 电话 奖学金 


S001 张 萍 志 ” 男 1989/12/1 物理 系 物理 学 687091234 。 1000 
S002 李 大 源 男 1990/1/12 教育 系 教育 史 687991234 。 200 
S003 刘 明 ” 女 ”1990/4/12 物理 系 物理 学 698721212 。 800 
S004 奉 丽 丽 女 。 199111 教育 系 学 前 教育 698712345 

S005 刘 明 男 教育 系 

S006 赵 丽 丽 男 生物 系 

123 


6-32 ”向 学 生 表 中 插入 数据 的 最 终 效果 图 


2) 设计 思路 
按照 图 6-32 的 样式 ,在 Web 窗 体 中 创建 一 个 FormView 和 一 个 GridView, 二 者 可 以 使 
用 一 个 共同 的 SqlDataSource 控件 。 


新 记录 通过 FormView 插入 ,因此 FormView 默认 为 插入 方式 。 记 录 被 保存 后 可 自动 
地 在 GridView 中 呈现 出 来 。 

3) 设计 过 程 

(1) 新 建 窗 体 并 布局 


新 建 一 个 Web 窗 体 ,命名 为 FormInsert。 在 其 [设计 了 视图 下 ,插入 一 个 表格 ,进行 适当 
布局 。 


(2) 添加 控件 并 初步 设置 
向 新 窗 体 中 的 单元 格 中 添加 标题 文字 “学 生 信息 输入 界面 >"“ 已 输入 学 生 的 名 单 :" 等 文 


字 , 并 适当 设置 文字 的 外 观 。 
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首先 从 【工具 箱 ] 的 [数据 3 栏目 下 拖 动 一 个 FormView 到 窗 体 的 适当 位 置 。 然 后 从 【 服 
务 器 资源 管理 器 面板 中 把 数据 连接 “XSGL. DBO” 下 的 表 “ 学 生 表 ” 拖 动 到 窗 体 的 适当 位 
置 ,系统 自动 创建 两 个 对 象 : GridViewl 和 SqlDataSourcel 。 


(3) 设置 相关 控件 属性 


利用 [属性 面板 依次 设置 相关 控件 的 属性 ,如 表 6-4 所 示 。 
表 6-4 设置 相关 控件 的 属性 


原始 控件 属 性 名 值 
SqlDataSourcel (ID) dsForm 
DefaultMode Jnsert 
FormViewl 
DataSourceID dsForm 
(ID) gvXsb 
GridViewl oe dsForm 
AllowPaging true 
PageSize 6 


(4) 配置 FormView 控件 

选择 FormViewl 控件 ,打开 其 智能 菜单 ,从 中 选择 【自动 套用 格式 】, 为 FormViewl 设 
置 外 观 格式 。 接 着 选择 [编辑 模板 】, 针 对 “InsertItemTemplate ”模板 进行 重新 布局 .调整 各 个 
数据 项 在 模板 中 的 位 置 。 修 正 模板 完成 后 , 单 击 【结束 编辑 模板 链接 ,返回 到 【设计 了 视图 。 

(5) 以 浏览 器 浏览 本 网 页 ,观察 效果 

2. 基于 FormView 的 记录 更 新 

尽管 GridView 也 提供 了 对 记录 的 编辑 功能 ,但 此 功能 把 所 有 记录 放 在 一 行 中 编辑 ,不 
适合 多 字段 记录 的 编辑 。 本 例 将 提供 一 种 针对 多 字段 记录 的 编辑 方式 。 

1) 案例 要 求 

制作 如 图 6-33 所 示 的 程序 ,使 之 可 先 通过 GridView 选 定 需要 编辑 的 学 生 , 然 后 以 
FormView 修改 学 生 的 信息 。 在 保存 修改 结果 后 ,会 自动 在 GridView 中 显示 出 编辑 的 结果 。 


[a) hp/iocalhosts971UFormEditaspx -|8[4|x 


| 六 9 有 才 看 W 《GE 内， 工具 0 和 动 册 


\ 


六 Wa | 
学 号 | 姓名 | 性 别 | 单位 | 编辑 记录 
S001 张 莹 志 女 ”物理 系 编辑 记录 学 号 ，S004 姓名 ， 崔 画 丽 
so0 李 大 源 男 ”教育 系 给 给 记录 性别， 去 证 
S003 刘 明 ” 女 ”物理 系 编辑 记录 单位 C7 
S004 内 画面 女 教育 系 编辑 记录 Sk 
S005 刘 明 。 男 。 教 系 编 给 记录 “电话 69871245 i 
so06 直面 而 男生 物 系 编 给 记录 人 对 


6-33 基于 FormView 实施 记录 更 新 的 最 终 效果 图 
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2) 设计 思路 

按照 图 6-33 的 样式 ,在 Web 窗 体 中 创建 一 个 FormView 和 一 个 GridView, 二 者 各 自 使 
用 独立 的 数据 源 控件 。FormView 使 用 的 数据 源 受 GridView 选 定 项 的 控制 。 

用 户 首先 通过 GridView 选 定 记录 ,然后 由 FormView 提供 编辑 和 保存 ,因此 
FormView 默认 为 编辑 方式 。 记 录 被 保存 后 可 自动 地 在 GridView 中 呈现 出 来 。 

3) 设计 过 程 

(1) 新 建 窗 体 并 布局 

新 建 一 个 Web 窗 体 , 命 名 为 FormEdit, 然 后 在 其 [设计 视图 下 ,插入 一 个 HTML 形式 
的 表格 ,通过 调整 其 中 单元 格 的 高 度 和 宽度 ,完成 页 面 的 布局 。 

(2) 添加 控件 并 初步 设置 

向 新 窗 体 中 的 单元 格 中 添加 标题 文字 “学 生 信息 编辑 ”等 文字 ,并 适当 设置 文字 的 外 观 。 

首先 ,从 【服务 器 资源 管理 器 ] 面 板 中 把 数据 连接 “XSGL. DBO” 下 的 表 “ 学 生 表 ” 拖 动 到 
窗 体 的 适当 位 置 ,系统 自动 创建 两 个 对 象 : GridViewl 和 SqlDataSourcel 。 

其 次 ,从 [工具 箱 ] 的 [数据 ] 栏 目下 拖 动 一 个 FormView 到 窗 体 的 适当 位 置 。 

最 后 ,复制 数据 源 对 象 SqlDataSourcel ,得 到 一 个 新 的 数据 源 对 象 SqlDataSource2 。 

(3) 设置 控件 属性 

利用 [属性 了 面板 依次 设置 相关 控件 的 属性 ,如 表 6-5 所 示 。 


表 6-5 设置 相关 控件 的 属性 


原始 控件 属 性 名 值 
SqlDataSourcel (ID) dsXsb 
SqlDataSource2 (ID) dsForm 

(ID) gvXsb 
i DataSourceID dsXsb 
ee AllowPaging true 
PageSize 6 
(ID) formXsb 
FormViewl DefaultMode Edit 
DataSourceID dsForm 


(4) 配置 FormView 控件 

选择 FormView1 控件 ,打开 其 智能 菜单 ,从 中 选择 【自动 套用 格式 】, 为 FormViewl 设 
置 外 观 格式 。 接 着 选择 [编辑 模板 】 ,针对 “EditItemTemplate” 模 板 进 行 重新 布局 ,调整 各 个 
数据 项 在 模板 中 的 位 置 。 修 正 模板 完成 后 , 单 击 【 结 束 编辑 模板 链接 ,返回 到 【设计 视图 。 

(5) 配置 GridView 控件 

选择 gvXsb 控件 ,打开 其 智能 菜单 。 首 先 ,从 中 选择 【自动 套用 格式 】, 为 gvXsb 设置 外 
观 格式 ; 其 次 ,从 智能 菜单 中 选择 [启用 选择 内 容 】, 为 gvXsb 增加 一 个 “选择 ” 列 ; 最 后 ,从 
智能 菜单 中 选择 [编辑 列 】 ,打开 [字段 ] 对 话 框 ,从 [已 选 定 的 字段 列表 框 中 删除 不 需要 的 字 
段 , 并 把 每 个 字段 的 HeaderText 属性 修改 为 中 文 文字 。 

(6) 配置 数据 源 dsForm 控件 ,使 之 接受 gvXsb 控件 的 控制 

选中 数据 源 dsForm 控件 ,从 [属性 ] 面 板 中 找到 SelectQuery 属性 ,打开 其 【命令 和 参数 
编辑 器 ] 对 话 框 ,为 编辑 器 添加 参数 xh, 并 把 参数 与 控件 gvXsb 关联 起 来 。 然 后 利用 [查询 
生成 器 设置 SQL 语句 ,最 终结 果 如 图 6-34 所 示 。 

(7) 保存 所 有 程序 ,以 浏览 器 预览 效果 
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SELECT 命 @: 
ELECT ph Baml Etbl [csdate], [dweil, [zhyel, [phonel [le] FROM 施 生 和 where xh=@xh 


图 6-34 参数 编辑 器 一 一 绑 定 学 号 与 GridView 的 选 定 值 相等 


注意 : 为 了 使 FormView 对 数据 的 更 新 能 及 时 地 反映 到 GridView 中 ,可 在 FormXsb 
的 ItemUpdated 事件 中 编写 如 下 代码 ， 


gvXsb. DataBind() ; 


3. 基于 Web 窗 体 标准 控件 的 记录 输入 程序 

除了 使 用 FormView 控件 实施 记录 的 输入 与 编辑 外 ,也 可 以 直接 利用 Web 的 标准 控件 
实现 记录 的 输入 。 

1) 案例 要 求 

制作 如 图 6-35 所 示 的 程序 ,通过 Web 标准 控件 向 “学 生 表 ” 中 插入 记录 ,能 够 在 
GridView 中 显示 出 插入 的 结果 。 


学 生 信 息 输入 


姓名 ， 


19971/1 生物 系 生物 史 。 12345678 200 
1989/12/1 物理 系 物理 学 687091234 1000 
1990/1/12 教育 系 教育 史 。 687991234 200 
199014/12 物理 系 物理 学 698721212 800 
1991U1 教育 系 学 前 教育 698712345 0 


图 6-35 基于 Web 窗 体 的 记录 输入 程序 的 最 终 效果 图 


MY 
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2) 设计 思路 

按照 图 6-35 的 样式 ,在 Web 窗 体 中 创建 一 个 GridView 和 若干 个 具有 特色 的 标准 
控件 。 其 中 ,在 创建 GridView 时 , VS2008 自动 创建 了 一 个 可 共用 的 SqlDataSource 
控件 。 

新 记录 通过 SqlDataSource 控件 的 InsertQuery 语句 及 其 绑 定 的 控件 实施 插 和 人 功能 。 
因此 ,利用 SqlDataSource 控件 对 其 他 标准 控件 进行 绑 定 是 本 设计 的 关键 问题 。 

新 记录 将 根据 数据 源 控件 的 Insert() 方 法 被 保存 ,然后 自动 地 在 GridView 中 呈现 
出 来 。 

3) 设计 过 程 

(1) 新 建 窗 体 并 布局 

新 建 一 个 Web 窗 体 ,命名 为 WebInput。 然 后 ,在 其 设计 了 视图 下 ,插入 一 个 表格 ,利用 
此 表格 进行 适当 的 页 面 布局 。 

(2) 添加 控件 并 初步 设置 

首先 ,向 新 窗 体 中 的 单元 格 中 添加 标题 文字 “学 生 信息 输入 ”等 文字 ,并 适当 设置 文字 的 
外 观 。 

其 次 ,从 【服务 器 资源 管理 器 ] 面 板 中 把 数据 连接 “XSGL. DBO” 下 的 表 “ 学 生 表 ” 拖 动 到 
窗 体 的 适当 位 置 ,系统 自动 创建 两 个 对 象 : GridViewl 和 SqlDataSourcel 。 

最 后 ,从 【工具 箱 ] 的 “标准 "下 拖 动 若干 个 控件 到 窗 体 的 适当 位 置 ,实现 如 图 6-35 所 示 
的 效果 。 

(3) 设置 控件 属性 

利用 [属性 面板 依次 设置 相关 控件 的 属性 ,如 表 6-6 所 示 。 


表 6-6 设置 控件 的 属性 


原始 控件 属 性 名 值 
SqlDataSourcel (ID) dsXsb 
(ID) gvXsb 
GridViewl DataSourceID dsXsb 
AllowPaging true 
PageSize 6 
TextBoxl (ID) txtXh 
TextBox2 (ID) txtXm 
TextBox3 (ID) txtSr 
TextBox4 (ID) txtZhy 
TextBox5 (ID) txtDh 
TextBox6 (ID) txtJxj 
(GD) rbIXb 
RadioButtonListl 水 加 选项 < 胃 5 和" 女 ” 
(ID) ddlDw 
ee 添加 选项 : 教育 系 .生物 系 .历史 系 .物理 系 等 
(ID) btnSave 
Button1 Tt 保存 
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(4) 配置 数据 源 dsXsb 控件 ,使 之 能 够 接收 各 Web 标准 控件 的 数据 
选中 数据 源 dsXsb 控件 ,从 [属性 了 面板 中 找到 InsertQuery 属性 ,打开 其 【命令 和 参数 
编辑 器 】 对 话 框 , 会 发 现 系统 已 经 自动 添加 了 各 字段 的 对 应 参数 ,现在 的 工作 就 是 把 各 参数 
与 Web 控件 连接 起 来 ,操作 后 的 结果 如 图 6-36 所 示 。 


INSERT 命令 (Q: 
INSERT INTO [学 生 友 ] (phl pml lxb], [csdatel [dwei] fzhye], [phonel We]) VALUES (@xh, 
@rm, @xb, @csdate Gdwei @zhye, Dphone, Bilje) 
[| msm | 
参数 E): 
2 徐 。。 什 
xm biXmTexct 
b rblXb.SelectedValu 
csdate baSrText 
dwei ddlDw.SelectedValue 
zhye bazhyText i 
phone ‘batDh.Text 
本 bt Text 
天 gaA | 
[Cw ] | w 


图 6-36 设置 数据 源 dsXsb 的 插入 语句 


参数 绑 定 控件 


注意 ; 当 Web 标准 控件 与 数据 源 控件 的 参数 建立 绑 定 关系 后 ,只 须 使 用 "数据 源 控件 
名 .Insert();” 方 法 即 可 完成 把 Web 控件 的 输入 数据 保存 到 数据 库 中 的 目的 。 

(5) 修改 aspx. cs 程序 代码 

回 到 [设计 视图 ,双击 [保存] 按钮 ,进入 到 C# 编程 状态 。 在 WebInput. aspx. cs 中 为 
btnSave_Click 添加 代码 ,如 图 6-37 所 示 。 

(6) 保存 所 有 程序 ,以 浏览 器 预览 效果 


231 et void btnSave Click(object sender, EventAres e) 

24: 

25 dsXsb. Insert 0 ; A/ 执行 数据 源 的 InsertQueryi 奎 句 ， 保存 数据 ; 
26: gvXsb. DatsBindQ; 。 // 把 新 数据 结果 反馈 到 cri aYi ex 中 

2 Etlh Text = // 集 他 天 时 ， 信 相关 文 本 杠 圭 人 才 扣 

28 txXtXm Tex 

29 txtSr. Text = ""; 

30 txtZhy. Text = ""; 


6-37 ”保存 数据 并 清空 所 有 控件 中 内 容 的 代码 


6.5.2 记录 的 批量 处 理 


1. 从 GridView 列表 中 选择 记录 并 批量 修改 

1) 案例 要 求 

设计 如 图 6-38 所 示 的 程序 。 在 学 生 列表 的 最 后 一 列 是 复 选 框 。 对 于 复 选 框 选中 的 学 
生 , 奖 学 金 增 加 100 元 。 对 于 原 奖学金 为 空 值 的 记录 , 则 认为 原 奖学金 为 0 元 。 
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| 加 rapyiocahostss711 7|B|5 [x Pp SEE pr 
Ec | 


充 KE | 者 [ 


提升 指定 学 生 的 奖学金 


学 号 | 姓名 | 性 别 | 生日 | 单位 | 专业 电话 “| 奖学金 选择 


Al00 张 荐 军 女 。 1997/W1 生物 系 生物 史 12345678 200 目 
S001 张 荐 志 1989/12/1 物理 系 物理 学 687091234 1000 目 
S002 李 大 源 199011/12 教育 系 教育 史 687991234 200 罩 
S003 刘 明 1990/4/12 物理 系 物理 学 698721212 800 目 
S004 在 丽 丽 199LU1 教育 系 学 前 教育 698712345 0 ”四 
S005 刘 明 日 
S006 赵 丽 丽 日 
S007 寿 糙 媛 目 


对 泗 泗 对 对 兽 对 


图 6-38 学 生 表 列 表 输 出 并 配置 CheckBox 模板 列 


2) 设计 思路 

创建 一 个 显示 学 生 信息 的 GridView。 在 这 个 GridView 的 末尾 增加 一 个 模板 列 , 把 一 
个 复 选 框 存放 到 模板 列 内 。 当 单 击 按钮 [提升 奖金 ] 时 ,会 逐条 记录 判定 ,如 果 该 复 选 框 被 选 
中 , 则 [奖学金 ] 字 段 的 值 增加 100 元 。 

3) 设计 流程 

(1) 新 建 窗 体 并 布局 

新 建 一 个 Web 窗 体 ,命名 为 AddJxj。 在 其 [设计] 视图 下 ,插入 一 个 表格 ,进行 适当 布局 。 

(2) 添加 控件 并 初步 设置 

向 新 窗 体 中 的 单元 格 中 添加 标题 文字 “提升 指定 学 生 的 奖学金 ,并 适当 设置 文字 的 外 观 。 

首先 ,从 【服务 器 资源 管理 器 ] 面 板 中 把 数据 连接 “XSGL. DBO” 下 的 表 “ 学 生 表 ” 拖 动 到 
窗 体 的 适当 位 置 , 系 统 自动 创建 两 个 对 象 GridViewl 和 SqlDataSourcel 。 

其 次 ,从 [工具 箱 ] 的 [标准 ] 栏 目下 拖 动 Button, 放 到 窗 体 的 适当 位 置 ,实现 如 图 6-38 所 
示 的 效果 。 

(3) 设置 控件 属性 

利用 [属性 面板 依次 设置 相关 控件 的 属性 ,如 表 6-7 所 示 。 

(4) 优化 gvXsb 控件 ,添加 模板 列 

选择 gvXsb 控件 ,打开 其 智能 菜单 。 首 先 ,从 中 选择 【自动 套用 格式 】 ,为 gvXsb 设置 外 
观 格式 ; 其 次 ,从 智能 菜单 中 选择 [编辑 列 】 ,打开 【 字 段 ] 对 话 框 ,从 [已 选 定 的 字段 3 栏目 中 
删除 不 需要 的 字段 ,并 把 每 个 字段 的 HeaderText 属性 修改 为 中 文 文字 ; 再 次 ,从 [字段 ] 对 
话 框 的 【可 用 字段 ] 中 选择 “TemplateField” 添 加 到 【已 选 定 的 字段 】 中 ,并 修改 其 
HeaderText 属性 为 “选择 ”; 最 后 ,退出 [编辑 列 ] 状 态 。 

从 gvXsb 控件 的 智能 菜单 中 选择 [编辑 模板 】, 打 开 编 辑 模板 的 对 话 框 ,如 图 6-39 所 示 。 
选择 “ItemTemplate” 模 板 ,为 模板 增加 一 个 CheckBox 控件 。 设置 此 CheckBox 控件 的 ID 
为 Ck,Text 属性 为 空白 。 最 后 , 单 击 链接 [结束 模板 编辑 】 ,退回 [设计 ] 视 图。 


第 6 章 ”SqlDataSource 访 问 数据 库 


表 6-7 相关 控件 的 属性 配置 


原始 控件 属 性 名 值 
SqlDataSourcel (ID) dsXsb 
(ID) gvXsb 
DataSourceID dsXsb 
GridViewl 2 
AllowPaging true 
PageSize 6 
(ID) btnJxj 
ope Text 提升 奖金 


Addlxjaspx” em] 
sp na I 


gyXsb - Columnl8] - 运 辽 |] niaview #2 


HemTemplate Ld 
[cy | ET 
Ficq 未 加 | 


结 过 模板 六 二 


6-39 为 GridView 设置 模板 列 ,并 编辑 模板 列 


(5) 修改 aspx. cs 代码 


回 到 [设计 视图 ,双击 按钮 [保存 】 ,进入 到 C# 编程 状态 。 在 AddJxj. aspx. cs 中 ,为 
btnJxj_Click 添加 代码 。 为 避免 奖学金 空 值 引起 的 计算 错误 ,为 Page_Load 增加 了 对 数据 


表 进 行 初始 化 的 代码 ,对 所 有 的 奖学金 为 空 值 的 记录 赋予 了 初 值 0。 
添加 的 代码 如 图 6-40 所 示 。 


14 日 nanespace DataSourceTest 

15 

lB publie partial class AddJxj : Systen. Web. UI. Page 

17 { 

18 日 protected yoid Page_Load (object sender, EventAres e) 

19 { 

20 if (IIsPostBack) 刀 1 是 初次 调用 这 个 页 面 

21 { 

22 dsXsb UpdateConmand = "update 学 生 素 set jlje=0 where jlje is noll;"; 

23 } dsXsb. Update 0 : ”// 把 奖学金 为 宇 值 的 记录 车 换 为 0 值 

24 

25 

28 

27 昌 protected void btnJxj_Click(object sender, EventAres e) 

28 { 

29 

30 foreach (Grid/ienRow gvr in gvXsb.Rows) // 对 Gri dyi ew 的 每 行 数据 进行 处 理 
31 { 

32 String xsxh = gvr.Cells[0]. Text. Trin 0; 71 获得 GridYiew 的 首 列 数值 (学 号 》 
33 CheckBox jlek = gvr.FindControl ("ck") as CheckBox; 

34 if (jlek Checked) 7 如 果 被 选中 了 

35 { 

36 String jxje = gwr.Cells[7].Text; 并 获得 原来 奖学金 的 值 

37 String jxj = Convert. ToString(Convert. ToInt32 (jxje.Trim0) + 100); 7/ 累加 100 元 
38 qls = String 了 ormat ("update 学 生 表 set jlje={0} where xh=' {1}’ ;", jxj, xsxh); 
39 dsXsb UpdateConmand = sqls; a 

40 ds¥Xsb. Update O; /执行 更 新 数据 的 命令 ， 更 新 记录 
41 } 

42 } evsb. DataBindO); 

43 } 

44 } 

45: +} 
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(6) 保存 所 有 程序 ,以 浏览 器 预览 效果 

2. 按照 课程 批量 录入 学 生成 绩 

1) 案例 要 求 

设计 如 图 6-41 所 示 的 程序 。 要 求 能 够 按照 课程 显示 出 学 生 选 课 的 列表 ,在 输入 考试 成 
绩 后 , 单 击 底部 的 [保存 按钮 , 即 可 把 输入 的 成 绩 保存 到 成 绩 表 中 。 

2) 设计 思路 

创建 一 个 显示 学 生 信息 的 GridView。 在 
这 个 GridView 中 增加 一 个 模板 列 , 把 一 个 文 
本 框 存放 到 模板 列 内 , 绑 定 到 成 绩 表 中 的 考试 | 四, 相 各 种 二 和 名 二 成 
成 绩 (Score) 字 段 上 。 当 单 击 按钮 【保存 】 时 ,会 3 S002 李 大 源 K001 力学 9100 。 2012/12/12 
逐条 记录 地 把 新 成 绩 保存 到 成 绩 表 中 。 

为 避免 一 次 出 现 的 记录 过 多 ,可 以 采用 
GridView 分 页 ,而 且 通 过 下 拉 式 列表 框 限 定 课 


请 选择 课程 名 称 : 力 半 。” 回 二 给 


图 6-41 选择 某 类 学 生 并 修改 其 成 绩 的 


终 
程 名 称 最 终 效 果 图 
GridView 的 数据 项 来 自 于 多 张 表 ,其 数据 源 建 立 在 多 表 连 接 的 基础 上 。 
3) 设计 流程 


(1) 新 建 窗 体 并 布局 

新 建 一 个 Web 窗 体 ,命名 为 ScoreGL。 在 其 [设计 了 视图 下 ,插入 一 个 表格 ,进行 适当 
布局 。 

(2) 添加 控件 并 初步 设置 

首先 ,向 新 窗 体 的 适当 位 置 添加 文字 “请 选择 课程 名 称 :” ,然后 添加 一 个 DropDownList 控 
件 和 一 个 Button 控件 ,初始 名 称 为 DropDownListl 和 Button1。 

其 次 ,从 【服务 器 资源 管理 器 ] 面 板 中 把 数据 连接 “XSGL. DBO” 下 的 表 “ 成 绩 表 ” 拖 动 到 
窗 体 的 中 部 位 置 ,系统 自动 创建 两 个 对 象 : GridViewl 和 SqlDataSourcel 。 

再 次 ,从 数据 连接 “XSGL. DBO” 下 把 表 “ 课 程 表 ” 拖 到 窗 体 的 底部 ,系统 自动 创 
建 对 象 GridView2 和 SqlDataSource2, 然 后 删除 GridView2, 只 保留 数据 源 对 象 
SqlDataSource2 。 

最 后 ,在 底部 加 入 一 个 Button 控件 ,其 初始 ID 为 Button2 。 

(3) 设置 控件 属性 

利用 [属性 面板 依次 设置 相关 控件 的 属性 ,如 表 6-8 所 示 。 


表 6-8 设置 相关 控件 的 属性 


原始 控件 属 性 名 值 
SqlDataSourcel (ID) dsCjb 
SqlDataSource2 (ID) dsKcb 

(ID) ddlKcb 
. DataSourceID dsKcb 
DropDownList 
DataTextField kcm 
DataValueField kch 
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续 表 

原始 控件 属 性 名 值 

(ID) gvCjb 

DataSourceID dsCijb 
GridViewl 

AllowPaging true 

PageSize 6 
ed (ID) btnkc 

Text 选 定 课程 

(ID) btnSave 
Button2 Text 保存 


(4) 设置 数据 源 dsCjb 控件 ,使 之 可 显示 多 表 数 据 

选中 数据 源 控件 dsCjb, 从 【属性 ] 面 板 中 找到 其 属性 “SelectQuery”。 通 过 
“SelectQuery” 右 侧 的 小 按钮 打开 【命令 和 参数 编辑 器 】 对 话 框 ,为 数据 源 控件 添加 参数 
kcbh, 而 且 让 参数 kcbh 绑 定 到 控件 ddIKcb。 

利用 右上 部 的 【查询 生成 器 按钮 打开 【查询 生成 器 〗。 首 先 , 右 击 上 部 区 域 , 从 弹出 菜单 
中 选择 [添加 表 】 ,把 “学 生 表 ”“ 课 程 表 ” 添 加 到 [查询 生成 器 ] 中 。 由 于 这 三 张 表 已 经 创建 过 
外 键 联系 ,所 以 它们 自动 创建 了 连接 。 其 次 ,利用 中 部 的 输出 “ 复 选 框 ” 选 择 要 输出 的 字段 
ID、xh、xm、kch、kem、score、kstime。 最 后 ,在 【筛选 器 ] 列 的 kch 行 输入 筛选 条 件 “@kch”， 
表示 查找 “kch” 等 于 参数 “@kch” 值 的 成 绩 记录 ,并 通过 “ORDER BY? 子 句 指明 按照 学 号 升 
序 输出 记录 。 

设置 后 的 [命令 和 参数 编辑 器 ] 对 话 框 如 图 6-42 所 示 。 


成 绩 表 zh, 学 生 囊 xm, 成 绩 表 .kch, 课程 表 kcm, 成 绩 表 .score, 成 绩 囊 jstime 
| FROM 成 顷 表 INNER JOIN 学 生 表 ON 成 半 表 .xh = 学 生 表 xh INNER JOIN 课程 表 ON 成 绩 表 kch 
= 课 如 表 .kch WHERE 


(成 时 表 kch = @kcbh) ORDER BY 成 污 表 ,| 


图 6-42 从 多 表 中 查询 数据 的 SELECT 语句 配置 器 


注意 : 顶部 窗口 中 的 SQL 命令 语句 由 查询 生成 器 以 可 视 化 操作 方式 生成 。 当 然 也 可 
直接 输入 正确 的 SQL 语句 。 

(5) 优化 gvCib 控件 ,添加 模板 列 

选择 gvCjb 控件 ,打开 其 智能 菜单 。 首 先 ,从 中 选择 【自动 套用 格式 】, 为 gvCib 设置 外 
观 格式 ; 其 次 ,从 智能 菜单 中 选择 [编辑 列 了 ,打开 【字段 】 对 话 框 , 从 [可 用 字段 】 中 挑选 字段 
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加 入 到 [已 选 定 的 字段 ] 列 表 框 中 ,同时 删除 不 需要 的 字段 ,并 把 每 个 字段 的 HeaderText 属 
性 修改 为 中 文 文字 。 特 别 要 注意 把 score 列 从 【已 选 定 的 字段 3 中 删除 。 再 次 ,从 【字段 ] 对 
话 框 的 [可 用 字段 ] 中 选择 “TemplateField”, 添 加 到 【 选 定 的 字段 ] 中 ,并 修改 其 HeaderText 


属性 为 “考试 成 绩 "。 最 后 ,退出 [编辑 列 ] 状 态 。 


从 gvXsb 控件 的 智能 菜单 中 选手 [编辑 模板 】， | ,syssgeg 和 ， [RW 本 和 
打开 【编辑 模板 】 对 话 框 。 选 择 【ItemTemplate】 ES 
模板 ,为 模板 增加 一 个 TextBox 控件 。 设置 此 [eed 


GridViewl -Column - 考 S 绩 ”站 


ptBoxssa 
TextBox 任务 


TextBox 控件 的 ID 为 sco, Text 属性 为 空白 ,如 
图 6-43 所 示 。 


单 击 此 文本 框 的 智能 按钮 ,选择 【编辑 CT] 
DataBindings】, 在 随后 弹出 的 对 话 框 中 为 Sco 绑 定 衣 


字段 “Score”。 最 后 , 单 击 GridView 的 智能 菜单 中 


6-43 配置 GridView 的 模板 列 ， 


的 链接 【结束 模板 编辑 】 ,退回 到 [设计 视图 。 
(6) 修改 aspx. cs 代码 


添加 TextBox 控件 


回 到 [设计 ] 视 图 ,双击 【 选 定 课程 ] 按 钮 ,进入 到 C# 编 程 状态 。 在 ScoreGl. aspx. cs 中 ， 


为 btnKc_Click 和 btnSave 添加 代码 ,如 图 6-44 所 示 。 


14 口 namespace DataSourceTest 

15 

public partial class ScoreGl : System. Web. UI.Page 
{ 


protected void Page_Load(object sender, EventAres e) 
{ 


} 


protected void btnSave Click(object sender, Eventhres e) 
{ 


dsCjb. UpdateConmand = sqls; 


} 
35 } 


37D protected void btnke_Click(object sender, Eventhres e) 


foreach (GridyiewRow gvr in gvCjb. Rows) /获取 Griayiex 的 每 一 行 
{ 


String cjID = gvr.Cells[0]. Text. TrinO; 册 获 取 当 前 行 的 成 绩 记 录 吕 
= gvr. FindControl ("Seo") as TextBox;  // 获 取 当 前 记录 的 成 续 值 
sqls = String, Pornat ("Update 成 绩 表 set t score={0] where ID={1}", 
cj. Text. Trim |), cjID); /形成 更 新 成 绩 的 Update 语 句 


dsCjb. Update | ; /1 执行 Updatei 
gvCjb. DataBindO); /ae dView 


并 
39 引 evCjb.Datapind(); /7 选 定 课程 后 ， 及 时 反映 到 cri ayiew 上 


6-44 ”保存 全 体 学 生成 绩 的 程序 代码 


(7) 保存 所 有 程序 ,以 浏览 器 预览 效果 


假 考题 


1. 什么 是 DataSource 控件 ? 在 .NET 3. 5 体系 中 ,DataSource 有 哪些 类 型 ? 
2. SqlDataSource 控件 的 配置 涉及 哪些 要 素 ? SqlDataSource 的 输出 有 哪些 类 型 ? 
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3. 如 何 利用 “服务 器 资源 管理 器 ”中 的 “数据 连接 ”创建 SqlDataSource 对 象 ? 如 何 利用 
【工具 箱 】 中 的 SqlDataSource 配置 SqlDataSource 对 象 ? 

4. 如 何以 SqlDataSource 更 新 后 台数 据 库 中 的 记录 ? 对 后 台数 据 库 中 的 数据 表 有 什么 
要 求 ? SqlDataSource 中 的 DataKeyNames 属性 有 什么 用 途 ? 

5. 如 果 需 要 把 窗 体 中 的 某 个 控件 与 SqlDataSource 控件 中 的 SQL 语句 联系 起 来 ,以 窗 
体 控件 作为 SQL 语句 的 参数 ,应 该 如 何 操作 ? 

6. 什么 是 GridView 控件 ? 它 与 FormView 和 DetailsView 控件 有 什么 不 同 ? 

7. GridView 中 的 “选择 ? 列 有 什么 作用 ? 在 启用 了 “ 选 定 内 容 ” 后 ,如 何 获 取 当 前 选 定 
记录 的 主键 值 ? 

8. 什么 是 GridView 的 模板 列 ? 如 何 为 GridView 增加 一 个 独立 的 CheckBox 列 或 
TextBox 列 ? 如 何 绑 定 模板 列 与 后 台数 据 库 的 相应 字段 ? 

9. 如 何 获取 GridView 中 模板 列 的 输入 数据 ? 
0. 在 GridView 的 “删除 ”“ 编 辑 ” 模 式 下 ,如 何 获取 当前 行 的 信息 ? 
1. Eval() 与 Bind() 命 令 有 什么 区 别 ? 
2. 如 何 使 用 SqlDataSource 对 象 实现 记录 删除 ? 
3. 如 何 使 用 SqlDataSource 对 象 实现 记录 插入 ? 
4. 如 何 利用 字符 串 参 数 方式 准备 SQL 语句 并 以 此 SQL 语句 作为 SqlDataSource 的 
命令 ? 
5. 在 利用 SqlDataSource 为 GridView 提供 数据 源 时 ,是 否 需要 执行 Select() 命 令 ? 
如 何 才能 让 GridView 控件 执行 刷新 功能 ? 
6. 如 何 才能 使 FormView 控件 的 默认 呈现 方式 为 Insert 状态 ? 


仁 机 实 训 是 


基于 第 5 章 创建 的 “商品 销售 系统 数据 库 ”, 新 建 商 品 销售 项 目 ShangPin, 在 此 项 目 中 
利用 SqlDataSource 完成 以 下 操作 。 

(1) 新 建 售货员 信息 管理 窗 体 Shouhuoyuan, 在 其 中 添加 GridView 控件 ,重点 显示 售 
货 员 信息 的 前 4 个 字段 ,并 为 GridView 添加 * 选 择 ? 列 “删除 ? 列 。 设 置 GridView 为 自动 
分 页 模式 ,每 页 显示 6 条 记录 。 

(2) 利用 “选择 ? 列 ,可 以 选 定 一 个 售货员 ,并 用 FormView 控件 显示 出 被 选 定 售货员 的 
详细 信息 ,而 且 可 以 切换 到 FormView 的 编辑 状态 ,对 选 定 的 售货员 进行 编辑 。 

(3) 利用 “删除 ” 列 的 按钮 ,可 以 把 被 单 击 的 售货员 删除 ,而 且 要 求 在 真正 执行 删除 命令 
前 先 要 核实 ,提问 “您 确实 想 删除 这 名 售货员 吗 ?”, 只 有 客户 选 定 “ 是 ”后 , 才 可 把 该 售货员 
删除 。 

(4) 利用 模板 列 ,为 GridView 添加 CheckBox 列 , 对 于 CheckBox 列 中 被 选中 的 所 有 售 
货 员 ,其 基本 工资 增长 200 元 。 

(5) 不 使 用 FormView 技术 ,而 是 直接 使 用 标准 控件 和 字符 串 参数 组 织 SQL 语句 , 然 
后 利用 为 SqlDataSource 配置 InsertCommand 语句 和 执行 Insert() 方 法 的 方式 实现 售货员 
信息 的 插入 。 
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LINQ 访 问 数 据 库 


学 习 要 点 

本 章 主 要 学 习 在 ASP.NET 下 以 LINGQ 技术 实现 数据 库 访 问 。 要 求 了 解 LINQ 的 概念 
与 发 展 ,掌握 以 LINQ 技 术 实 现 记录 查询 .记录 修改 记录 插入 和 记录 删除 的 关键 流程 ,简要 
了 解 LINQ 操作 XML 的 方法 。 本 章 要 求 重 点 关注 以 下 内 容 : 

。 在 项 目 中 创建 LINQ to SQL 类 和 实体 类 的 技术 。 

。 LINQ 查询 表达 式 的 格式 与 撰写 方法 。 

。 以 LINQ 实现 记录 插入 、 删 除 和 更 新 的 技术 。 


0.1 LINO 技术 简介 
有 


最 近 20 年 ,面向 对 象 编程 技术 在 信息 系统 开发 的 应 用 已 经 进入 了 一 个 稳定 的 发 展 阶 
段 。 程 序 员 现 在 都 已 经 认同 类 (class) 、 对 象 (object) ,方法 (method) 这 样 的 语言 特性 。 而 
针对 数据 库 的 操作 则 是 基于 另外 一 条 线 的 一 一 以 基于 关系 数据 库 的 SQL 语句 实施 数据 
管理 。 

在 信息 系统 开发 和 动态 网 站 的 建设 中 ,传统 的 方法 是 采用 在 高 级 语言 中 嵌入 SQL 语句 
的 方式 实现 二 者 的 结合 。 在 这 种 结构 中 ,高 级 语言 不 负责 SQL 语句 的 语法 检查 ,开发 者 必 
须 把 SQL 语句 提交 给 DBMS 处 理 后 才能 验证 其 有 效 性 ,而 且 需要 开发 者 解决 SQL 语句 的 
集合 处 理 模式 与 高 级 语言 的 单 记录 处 理 模 式 之 间 的 矛盾 ,综合 处 理 二 者 之 间 的 通信 问题 . 变 
量 交 换 等 问题 。 

为 了 使 高 级 语言 程序 设计 与 数据 库 操作 能 够 在 同一 体系 下 开发 ,使 开发 者 对 数据 库 的 
操作 能 和 操作 本 地 对 象 一 样 方便 ,在 高 级 语言 体系 中 直接 内 置 数据 库 操作 对 象 ,形成 一 套 内 
置 于 高 级 语言 体系 中 的 数据 库 操作 技术 就 成 为 许多 高 级 语言 的 发 展 方向 之 一 。LINGQ 技术 
就 是 这 种 技术 之 一 。 


7.1.1 什么 是 LINO 技术 


1. LINO 技术 的 起 源 与 目标 

LINQ 即 语言 集成 查询 (Language Integrated Query,LINQ) ,是 Microsoft 为 解决 以 面 
向 对 象 的 程序 设计 方法 访问 数据 库 而 开发 的 一 种 技术 ,这 种 技术 基于 .NET Framework ,为 
多 种 数据 源 的 查询 提供 了 统一 的 语法 ,以 对 象 的 视角 看 待 数据 库 。 它 能 够 与 .NET 支持 的 
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编程 语言 (Visual Basic 和 C# ) 整 合 为 一 体 ,使 得 对 数据 库 的 访问 功能 直接 被 嵌入 编程 语言 
的 代码 中 ,被 高 级 语言 的 编译 系统 统一 地 管理 。 它 能 够 充分 利用 VS2008 的 智能 提示 功能 ， 
使 用 高 级 语言 的 编译 器 也 能 检查 查询 语句 的 语法 错误 。 可 以 说 ,LINQ 是 一 组 用 于 C# 和 
Visual Basic 语言 的 扩展 , 它 允 许 编写 C# 或 者 Visual Basic 代码 以 操作 内 存 数据 的 方式 查 
询 数据 库 , 以 对 象 的 视角 看 待 和 管理 数据 库 。 

2. LINQ 技术 的 类 型 

与 DataSource 的 理念 相似 ,为 解决 不 同 数据 类 型 的 操作 问题 ,LINQ 也 提供 了 针对 不 
同类 型 数据 的 类 。 主 要 有 LINQ to Object、 LINQ to SQL .LINQ to XML 和 LINQ to 
DataSet 等 。 其 中 ,LINQ to Object 主要 用 于 连接 数组 和 列表 等 集合 类 型 ,LINQ to SQL 用 
于 解决 关系 数据 库 的 操作 问题 ,而 LINQ to XML 面向 XML 数据 ,LINQ to DataSet 面向 
DataSet 型 数据 。 

LINQ 提供 了 面向 不 同类 型 数据 的 类 (class)。 当 针对 具体 数据 的 对 象 建立 后 , LINQ 
提供 了 像 操作 本 地 对 象 一 样 的 .统一 的 操作 模式 ,使 开发 者 可 以 便利 地 操作 各 种 类 型 的 
数据 。 


7.1.2 LINO to SOL 技术 


LINQ to SQL 为 关系 数据 库 提供 了 一 个 对 象 模型 , 即 把 关系 数据 库 映 射 为 类 对 象 ,使 
开发 者 可 以 用 操作 对 象 的 方式 实现 对 记录 的 查询 .修改 ,删除 和 插入 操作 。 表 7-1 列 出 了 关 
系数 据 库 中 的 概念 与 LINQ 概念 之 间 的 对 应 关系 。 


表 7-1 关系 数据 库 概念 与 LINQ 概念 之 间 的 对 应 关系 


关系 数据 库 的 概念 LINQ 的 概念 关系 数据 库 的 概念 LINQ 的 概念 
数据 库 DataContext 对 象 外 键 关系 关联 
数据 表 实体 类 对 象 存储 过 程 方法 
属性 (字段 ) 属性 (成 员 变量 ) 


从 表 7-1 可 以 看 出 ,LINQ 会 把 一 个 数据 库 映 射 为 一 个 DataContext 对 象 ,把 数据 库 中 
的 数据 表 映 射 为 多 个 实体 类 对 象 ,数据 表 中 的 属性 (字段 ) 将 成 为 实体 类 的 列 (Column) 或 者 
成 为 成 员 变量 。 因 此 一 个 LINQ 的 DataContext 对 象 反 映 了 整个 数据 库 的 结构 ,而 且 封 装 
了 针对 数据 库 实 施 操作 的 一 些 方法 (函数 )。 这 些 方法 提供 了 统一 对 数据 库 实 施 操作 的 
技术 。 

依据 关系 数据 库 创 建 LINQ 对 象 的 操作 可 由 VS2008 自动 完成 ,也 可 由 开发 者 自行 建 
立 。 当 然 ,“ 自 动 完成 "具有 速度 快 . 开 发 效率 高 ,设置 规范 等 特点 ,是 常见 的 方式 。 


7.1.3 ” LINQ 的 查询 表达 式 


LINQ 查询 表达 式 是 LINQ 实现 数据 操作 的 基本 语句 ,是 ASP.NET 技术 对 C# 或 
Visual Basic 语言 的 扩展 ,可 以 和 其 他 的 高 级 语言 语句 一 样 看 做 是 高 级 语言 的 组 成 部 分 。 

由 于 LINQ 主要 面向 复杂 数据 类 型 操作 ,而 这 些 数据 的 内 部 结构 具有 多 样 性 ,为 此 
LINQ 常常 使 用 隐 类 型 变量 存放 返回 数据 , 即 在 变量 定义 之 初 把 它 定义 成 不 明确 结构 的 var 
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类 型 ,在 程序 真正 地 运行 时 才 根 据 运 行 结果 填充 相应 的 数据 类 型 。 
1. LINQ 查询 表达 式 的 基本 形式 
与 SQL 语言 相似 ,LINQ 的 查询 表达 式 也 有 一 个 基本 的 格式 ,大 多 数 查询 都 可 以 依托 
此 格式 进行 设计 。LINQ 查询 表达 式 的 基本 形式 如 下 : 
var result = from r in <DataContext 对 象 >.< 实 例 类 对 象 > 
[where < 条 件 式 >] 
[group r by r.< 列 名 > [into g]] 
[orderby r.< 列 名 >] 
select [r; | new 
{ .< 列 名 >, .< 列 名 >,… 
9g. 统计 函数 (< 列 名 >) … ]; 
从 上 述 基本 格式 可 知 ,LINQ 的 查询 表达 式 必须 以 from 子 句 开始 ,说 明 从 什么 地 方 提 
取 数 据 。 以 select 或 者 group 子 句 结束 ,表示 输出 结果 ,语句 执行 完毕 ,变量 result 中 存储 
的 就 是 select 子 句 或 group 子 句 指定 的 输出 结果 。 在 这 两 者 之 间 可 以 包括 where group 
by、orderby 等 子 句 ,甚至 可 以 嵌 套 使 用 from ,join \let 等 子 句 。 
与 标准 SQL 语句 不 同 ,LINQ 语句 以 from 开始 ,其 目的 在 于 让 集成 化 开发 环境 尽快 知 
道 查询 的 数据 源 ,从 而 为 后 续 语 句 的 设计 提供 智能 化 的 引导 。 
2. LINQ 查询 表达 式 子 句 的 含义 
LINQ 查询 表达 式 与 SQL 语句 相似 ,包含 了 8 个 子 句 。 比 较 关 键 的 子 句 是 where、 
select 和 group by。where 子 句 表示 查询 条 件 , 执 行 记录 选择 操作 。group by 表示 对 记录 
进行 分 组 。 如 果 输 出 全 部 字段 ,select 子 句 直接 使 用 select r 即 可 。 如 果 需 要 投影 输出 部 分 
字段 , 则 需要 另外 定义 变量 new, 并 随 之 说 明 new 中 包含 的 列 名 。 
下 面 简单 介绍 各 个 子 句 的 含义 。 
。 from 子 句 一 一 指定 查询 操作 的 数据 源 ,通常 是 一 个 实体 类 对 象 的 名 称 。 
where 子 句 一 一 指定 查询 条 件 ,通常 是 一 个 条 件 表达 式 。 
。 select 子 句 一 一 指定 查询 结果 的 类 型 ,通常 是 记录 变量 名 、 或 者 由 列 名 、 统 计 函 数 表 
达 式 构成 的 集合 变量 。 
。 group 子 句 一 一 对 查询 结果 进行 分 组 ,后 面 通常 跟 作 为 分 组 依据 的 列 名 。 
。 orderby 子 句 一 一 对 查询 结果 进行 排序 。 
。 join 子 句 一 一 实现 多 个 查询 数据 源 的 连接 。 
。 let 子 句 一 一 引入 范围 变量 。 
， into 子 句 一 一 指向 一 个 临时 标识 符 , 把 操作 的 中 间 结 果 保 存 到 这 个 标识 符 命名 的 临 
时 变量 中 。 
3. LINQ 查询 表达 式 示例 
假设 已 经 定义 了 DataContext 对 象 mydb, 其 中 包括 一 个 实体 对 象 “ 学 生 表 ”, 学 生 表 
包括 了 学 号 、 姓 名、 性 别 、 生 日 .电话 、 奖 学 金 、 单 位 等 列 。 那 么 可 利用 LINQ 实现 以 下 
查询 。 
(1) 查询 学 生 表 的 全 部 信息 


var result = from r in mydb. 学 生 表 select r; 
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(2) 查询 学 生 表 中 教育 系 学 生 的 信息 
var result = from r in mydb. 学 生 表 where 单位 == "教育 系 " select r; 
注意 : 在 C# 中 判断 二 者 相等 使 用 “二 二 ”符号 ,不 能 只 写 一 个 “二 ”号 。 
(3) 查询 姓名 中 包含 文字 “ 兰 " 字 的 学 生 
var result = from r in mydb. 学 生 表 where SqlMethods.Like(r. 姓 名 ," 兰 ") 
Select r; 
注意 : 字符 串 的 模糊 查询 可 以 使 用 SqlMethods. Like 方法 进行 处 理 。 
(4) 查询 学 生 表 中 教育 系 学 生 的 姓名 、 性 别 
var result = from r mydb. 学 生 表 where 单位 == "教育 系 " 
select new {r. 姓 名 ,r. 性 别 }; 
(5) 查询 每 个 单位 的 学 生 人 数 , 及 其 学 生 获 得 奖学金 的 总 额 
var result = from r mydb. 学 生 表 group r by r. 单 位 into g 
select new { Key = g. Key, Count = g.Count(), sumjl=g.Sum(p=>p. 奖 学 金 ); 
上 述 5 个 操作 获得 的 对 象 result 是 一 个 位 于 内 存 中 的 二 维 表 对 象 ,可 直接 被 GridView 
等 数据 库 控件 绑 定 , 以 适当 的 形式 呈现 出 来 。 
另外 ,由 于 LINQ 语句 中 涉及 的 数据 都 是 以 对 象 的 形式 存在 的 ,因此 相关 的 变量 可 以 看 
做 是 内 存 变 量 , 其 操作 语句 属于 高 级 语言 范畴 的 程序 语句 。 所 以 其 变量 可 以 直接 被 内 存 变 
量 赋值 ,也 可 以 直接 被 读 取 并 赋值 到 其 他 变量 中 。 在 LINQ 查询 语句 中 可 以 直接 使 用 控件 
变量 ,也 可 以 使 用 大 部 分 的 C# 的 运算 符 .函数 。 例 如 : 


var result = from r mydb. 学 生 表 where 单位 == TextBoxl. Text select r; 


(3 VS2008 的 LINQ to SQL 体系 


7.2.1 VS2008 项 目 应 用 LINO 技术 的 流程 


要 在 VS2008 项 目 中 使 用 LINQ 技术 ,必须 引入 LINQ 命名 空间 ,并 创建 DataContext 
对 象 ,以 此 对 象 作为 关系 数据 库 的 映射 ,把 对 关系 数据 库 的 操作 转化 为 对 DataContext 对 象 
的 操作 。 其 关键 流程 如 下 。 

1. 为 数据 库 项 目 增加 DataContext 类 

为 数据 库 项 目 增加 DataContext 类 的 过 程 就 是 添加 LINQ to SQL 类 的 过 程 。 即 向 项 
目 中 新 建 一 个 LINQ to SQL 类 定义 ,然后 借助 [服务 器 资源 管理 器 ] 面 板 中 的 “数据 连接 ”把 
相关 数据 表 添 加 到 其 中 ,形成 一 个 DataContext 对 象 。 

在 这 一 过 程 中 ,系统 会 自动 把 命名 空间 System. linq 添加 到 程序 中 ; 并 自动 为 相关 数据 
表 创 建 对 应 的 实体 类 。 实 体 类 的 名 称 与 数据 表 名 称 相同 。 

2. 基于 DataContext 对 象 实施 查询 操作 

在 创建 了 DataContext 对 象 后 ,就 可 以 利用 LINQ 的 查询 表达 式 构造 查询 语句 了 。 
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针对 LINQ 查询 语句 ,通常 会 获得 一 个 记录 集 变 量 。 假 设 这 个 变量 的 名 字 是 result, 那 


么 很 多 操作 都 可 以 建立 在 这 个 result 变量 的 基础 上 。 


(1) 把 result 记录 集 对 象 显示 出 来 一 一 把 此 变量 赋予 GridViewl 对 象 
GridView1. DataSource = result; GridView1.DataBind(); 
(2) 把 首 条 记录 的 值 赋予 控件 对 象 一 一 直接 赋 到 控件 的 对 应 属性 上 


var rec = result. first(); 
TextBoxl. Text = rec.< 字 段 名 >; 


(3) 逐条 记录 进行 处 理 一 一 把 记录 集 看 成 记录 的 集合 ,逐个 读 取 并 处 理 


foreach(var rec in result) { 
// 此 时 可 以 把 rec 看 成 一 个 结构 变量 类 型 , 对 各 个 字段 任意 处 理 
} 
3. 基于 DataContext 对 象 的 删除 操作 
首先 ,利用 LINQ 查询 表达 式 获 取 一 个 记录 集 变 量 result, 然 后 只 须 使 用 命令 


<DataContext 对 象 名 >.< 实 体 类 对 象 名 >. DeleteAllOnSubmit(result); 
<DataContext 对 象 名 >. SubmitChanges( ); 


就 会 把 记录 集 内 包含 的 记录 全 部 删除 。 


4. 基于 DataContext 对 象 的 记录 修改 操作 
首先 ,利用 LINQ 查询 表达 式 获取 一 个 记录 集 变量 result。 
通常 这 个 记录 集中 只 有 一 条 记录 ,因此 只 须 使 用 赋值 语句 把 新 值 赋予 该 记录 对 象 的 相 


应 列 , 然 后 利用 DataContext 对 象 更 新 后 台数 据 库 即 可 。 


var rec = result. first(); // 获 取 记 录 对 象 
rec.< 字 段 名 > =< 新 值 >; .…. // 为 字段 赋予 新 的 数据 
<DataContext 对 象 名 >. SubmitChanges( ); // 更 新 到 后 台数 据 库 


如 果 获得 的 记录 集 是 多 条 记录 , 则 可 以 逐条 获取 ,逐条 赋值 ,最 后 集中 更 新 后 台数 据 库 。 


foreach(var rec in result){ // 获 取 每 一 条 记录 
rec.< 字 段 名 > = < 新 值 >; … // 为 当前 记录 的 字段 赋予 新 值 


} 
<DataContext 对 象 名 >. SubmitChanges();  // 更 新 到 后 台数 据 库 


5. 基于 DataContext 对 象 的 插入 操作 
由 于 在 DataContext 对 象 中 已 经 为 数据 库 中 的 数据 表 创 建 了 对 应 的 实体 类 。 因 此 可 以 


利 月 


实体 类 实现 记录 插入 操作 。 假 设 原始 的 数据 表 中 包含 一 个 学 生 表 , 表 名 为 XSB, 那 么 


新 增 记录 的 操作 为 : 


XSB rec = new XSB( ); // 创 建 一 个 学 生 表 的 记录 对 象 
rec.< 字 段 名 >= < 新 值 > 


<DataContext 对 象 名 >. XSB. InsertOnSubmit(rec); 
<DataContext 对 象 名 >. SubmitChanges( ); 
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注意 : 基于 DataContext 的 数据 库 更 新 操作 也 要 求 数据 列 中 包括 表 的 主键 ,满足 数据 
库 实施 更 新 的 基本 条 件 。 


7.2.2 在 VS2008 项 目 中 创建 DataConText 类 


假设 学 生 管 理 数 据 库 (XSGL) 已 经 存在 , 共 包 括 学 生 表 、 课 程 表 和 成 绩 表 三 张 数据 表 ， 
数据 表 的 结构 如 5. 1. 2 节 所 述 。 

VS2008 已 经 创建 了 针对 学 生 管理 数据 库 的 数据 连接 ,该 连接 已 经 在 VS2008 的 【服务 
器 资源 管理 器 了 面板 中 存在 。 现 在 需要 创建 一 个 项 目 , 此 项 目 将 借助 LINQ 技术 访问 XSGL 
数据 库 。 

1. 为 新 Web 项 目 添加 DataContext 类 

启动 VS2008 ,使 用 系统 菜单 [文件 】 项目, 选择" Web”“ASP.NET 应 用 程序 ”, 然 
后 输入 项 目 名 称 MyLINQ。 最 后 单 击 【确定 按钮 ,系统 自动 创建 一 个 名 称 为 MyLINQ 的 
新 项 目 。 

在 【解决 方案 资源 管理 器 】 面 板 中 右 击 项 目 名 称 MyLINQ, 在 弹出 的 菜单 中 选择 【添加 】~>~ 
【新 建 项 】, 然 后 从 各 种 模板 中 选择 *LINQ to SQL 类 ”, 在 底部 的 【名 称 】 文 本 框 中 输入 新 名 
称 “mydb. dbml”。 最 后 单 击 【添加 ] 按 钮 ,把 mydb 添加 到 项 目 中 。 

此 时 系统 会 自动 进入 到 针对 mydb. dbml 实施 配置 的 状态 ,系统 界面 如 图 7-1 所 示 。 


文件 四 。” 编 久 日、 视 加 WJ 项 四 生成 泽 KD) IROD 于 #5) 窑 DW) 帮 助 -td 
E 涪 -" 区 加 眉 "Pe 2- Bl Debug 


se 
Mn Nsl[ Nn ml Nn re 
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7-1 新 建 LINQ to SQL 类 的 操作 界面 


最 左 侧 的 面板 是 [服务 器 资源 管理 器 】 面 板 , 左 侧 第 2 个 面板 是 创建 “数据 类 ”的 面板 , 左 
侧 第 3 个 面板 是 创建 “方法 ”的 面板 。 最 右 侧 的 面板 是 [解决 方案 资源 管理 器 ] 面 板 。 

注意 : 如 果 【 服 务 器 资源 管理 器 ] 面 板 或 [解决 方案 资源 管理 器 ] 面 板 不 在 屏幕 上 , 则 可 
以 通过 系统 菜单 [视图] 把 它们 调 出 来 。 
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2. 为 mydb 创建 实体 类 

展开 [服务 器 资源 管理 器 面板 中 的 数据 连接 “XSGL. DBO”, 从 其 “ 表 ” 的 子 项 中 依次 把 
3 个 数据 表 “ 学 生 表 ”“ 课 程 表 ”和 “成 绩 表 ” 拖 动 到 “数据 类 ”面板 中 。 此 时 系统 自动 为 这 三 
张 表 创建 了 对 应 的 实体 类 ,如 图 7-2 所 示 。 

如 果 在 数据 库 创建 的 时 候 已 经 为 这 3 张 表 
建立 了 关系 ,那么 这 3 张 表 被 添加 到 数据 类 面板 
后 ,就 会 自动 地 保留 这 种 关联 关系 。 反 之 ,如 果 
发 现 添 加 到 数据 类 面板 中 的 这 3 张 表 之 间 没 有 
关系 ,那么 需要 根据 语义 为 这 3 张 表 建立 关联 。 
具体 方法 是 : 右 击 “成 绩 表 ”, 在 其 快捷 菜单 中 选 
择 [添加 】>【 关 联 】, 系统 会 打开 [关联 编辑 器 】 对 
话 框 ,如 图 7-3 所 示 。 创 建 “课程 表 的 课程 号 | 
(kch)” 与 “成 绩 表 的 课程 号 (kch)” 之 间 的 关联 和 
“学 生 表 的 学 号 (xh)” 与 “成 绩 表 的 学 号 (xh) "之 
间 的 关联 。 图 7-3 所 示 为 课程 表 与 成 绩 表 之 间 创 
建 关 联 的 界面 。 


2 了 GO: 

课程 表 了 | | 成 - 

关联 是 性 A)}: 

课程 表 属性 成 法 表 尾 性 

kch a kch 1 
Lm | 


7-3 新建 LINQ 实体 类 之 间 的 关联 


对 实体 类 配置 完毕 ,就 可 关闭 mydb. dbml 文档 了 。 

3. 对 mydb.dbml 文档 的 解释 

在 为 项 目 添加 和 配置 LINQ to SQL 类 完毕 ,会 发 现 【解决 方案 管理 器 】 面 板 中 添加 了 一 
个 新 的 资源 “mydb. dbml”, 其 中 包括 两 个 子 项 “mydb. dbml. Layout” 和 “mydb. designer 
区 

子 项 mydb. dbml. Layout 定义 了 每 个 数据 表 在 设计 视图 中 的 布局 。mydb. designer. cs 
则 定义 了 自动 生成 的 多 个 类 (class), 例 如 ,在 本 项 目 中 ,包括 DataContext 类 派生 的 
mydbDataContext 类 .与 数据 库 XSGL 对 应 的 类 ,与 各 个 数据 表 ( 学 生 表 、 课 程 表 、 成 绩 表 
等 ) 对 应 的 实体 类 等 。 

为 了 实施 对 实体 类 的 操作 ,实体 类 包含 了 多 个 内 部 类 ,其 中 的 TableAttribute 类 负责 管理 
与 数据 表 密 切 相关 的 信息 ,比如 其 中 的 属性 "Name” 就 指明 了 数据 表 的 名 称 ; ColumnAttribute 
类 负责 管理 与 表 结 构 相 关 的 信息 ,明确 列 之 间 的 映射 关系 ; AssociationAttribute 类 映射 数据 表 
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之 间 的 关联 关系 ; FunctionAttribute 类 负责 对 存储 过 程 的 管理 ,并 通过 ParameterAttribute 
类 实现 参数 传递 与 控制 。 
对 于 mydb. dbml 文档 的 内 部 机 理 , 初 学 者 可 暂 不 关注 。 


7.2.3 基于 DataContext 的 简单 应 用 程序 


在 项 目 中 添加 并 配置 了 LINQ to SQL 类 后 ,就 可 以 借助 DataContext 技术 实现 Web 
应 用 程序 开发 了 。 

在 Web 应 用 程序 开发 中 ,LINQ 查询 表达 式 和 其 他 的 C# 语 句 一 起 被 编写 到 cs 文档 
中 ,用 于 相应 窗 体 控件 的 各 类 事件 。 

下 面 将 通过 4 个 例子 说 明 借助 于 LINQ 技术 的 开发 过 程 。 在 下 面 的 例子 中 ,假设 项 目 
MyLINQ 已 经 创建 ,并 且 在 项 目 MyLINQ 中 添加 了 一 个 关于 数据 库 “ 学 生 管 理 (XSGL)” 的 
名 字 为 mydb 的 LINQ to SQL 类 。 

1. 借助 LINQ 技术 实现 对 学 生 表 的 查询 

1) 案例 要 求 

编写 程序 ,实现 如 图 7-4 所 示 的 功能 ,使 程序 能 够 根据 学 号 显示 出 学 生 的 信息 。 


请 输入 学 生 姓 名 ， 季 大 源 要 


S002 李 大 源 男 1990/1/12 00000 教育 系 教育 史 687991234 0 


图 7-4 以 LINQ 设计 查询 程序 的 最 终 效果 图 


2) 设计 过 程 

(1) 新 建 Web 窗 体 , 命 名 为 DispAll。 在 其 [设计 3 视图 下 ,首先 利用 表格 进行 简单 的 页 
面 布 局 ,并 输入 提示 文字 “请 输入 学 生 姓名 :”。 

(2) 从 [工具 箱 ] 的 [标准 栏目 下 拖 动 一 个 TextBox 到 人 窗 体 中 ,修改 其 ID 为 txtXm。 然 
后 从 [工具 箱 ] 的 [数据] 栏目 下 拖 动 一 个 GridView 到 窗 体 的 适当 位 置 ,修改 其 ID 为 
gvXscx。 最 后 从 【工具 箱 ] 的 【标准 ] 栏 目下 拖 动 一 个 Button 放 到 TextBox 后 面 ,修改 
Button 的 ID 为 btnLook,Text 值 为 “查找 ”。 

(3) 双击 【查找 了 按钮 ,进入 C# 代 码 设 计 状 态 ,为 btnLook_Click 方法 编写 代码 。 最 终 
得 到 的 程序 语句 如 图 7-5 所 示 。 

3) 总 结 

(1) 从 本 例 可 知 ,在 使 用 LINQ 操作 数据 库 时 ,需要 使 用 mydbDataContext 类 创建 一 个 
数据 库 类 的 对 象 db, 然 后 各 种 操作 都 是 针对 这 个 db 对 象 的 。 

(2) 熟练 掌握 LINQ 查询 表达 式 的 设计 对 于 应 用 LINQ 技术 至 为 关键 。 

2. 依托 LINO 技术 设计 课程 表 的 插入 程序 

1) 案例 要 求 

使 用 LINQ 技术 编写 课程 信息 输入 程序 ,使 课程 信息 输入 后 能 够 在 底部 的 GridView 
中 显示 出 来 。 要 求实 现 的 界面 如 图 7-6 所 示 。 
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14:0namespace IlyLI 阳 

15:| { 

publie partial aass Default + Systen, Web. UT.Page 
{ 


mydbDataContext db=new mydbDataContext(); fj 新 建 一 个 ataContext 对 象 
protected void Page Load (object sender, EventAres e) 

下 

| 


protected void btnLook Clicklobject sender, Eventhres e) 


var result=from r in db. 学 生 表 where .xm==txtXm. Text. Trim () 

select r; 4f1INQ 的 查 词 表达 式 ， 结 果 存 放 在 result 中 ; 
gvXscx. DataSource = result; /把 查 伺 结果 县 予 GridYiew 对 象 
evisex. DataBind(); 


7-5 以 LINQ 实现 查询 的 C# 代 码 


7-6 利用 LINQ 实现 记录 插入 的 最 终 效 果 图 


2) 设计 过 程 

(1) 新 建 Web 窗 体 ,命名 为 KcbInsert。 在 其 [设计] 视图 下 ,首先 利用 表格 进行 简单 的 
页 面 布局 ,并 输入 提示 文字 :“ 课 程 表 信息 输入 ”, 适 当 设 置 文 字 的 外 观 。 

(2) 从 [工具 箱 ] 的 【标准 ] 栏 目下 拖 动 4 个 TextBox 到 窗 体 中 ,依次 设置 其 ID 为 
txtXh、txtXm、txtXf、txtKkdw。 然 后 从 【工具 箱 ] 的 [标准] 栏目 下 拖 动 一 个 Button 放 到 
TextBox 后 面 ,修改 Button 的 ID 为 btnSave,Text 值 为 “插入 ”。 最 后 从 [工具 箱 】 的 【数据 】 
栏目 下 拖 动 一 个 GridView 到 窗 体 的 适当 位 置 ,修改 其 ID 为 gvKcb。 

(3) 双击 [插入] 按钮 ,进入 C# 代 码 设 计 状 态 ,为 btnSave_Click 方法 编写 代码 。 最 终 
得 到 的 程序 语句 如 图 7-7 所 示 ( 此 处 忽略 了 若干 个 using 语句 ) 。 

3. 使 用 LINQ 技术 实现 多 表 查 询 

1) 案例 要 求 

使 用 LINQ 技术 编写 综合 查询 程序 ,能 够 查询 出 指定 课程 的 学 生 选 修 课 程 及 其 考试 成 
绩 的 情况 。 要 求实 现 的 界面 如 图 7-8 所 示 。 

2) 设计 过 程 

(1) 新 建 Web 窗 体 ,命名 为 MultiTable。 在 其 [设计 了 视图 下 ,首先 利用 表格 进行 简单 
的 页 面 布局 ,并 输入 提示 文字 “学 生 选 课 情 况 查询 ”和 ”请 选择 学 生 的 所 在 单位 :”, 适 当 设置 
文字 的 外 观 。 
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14D nanespace MyLINQ 
{ 


15 

16i9 public partial class KcbInsert : Systenm. Web.UI.Page 

180 protected void Page Load(object sender, EventAres e) 

19 { 

20 

21 } 

22 

230 protected void btnSave_Click (object sender, Eventhres e) 

24 { 

L265: mydbDataContext db = new mydbDataContext(); /1 创建 DataContext 对 象 邮 
26 课程 表 kcb = new 课程 表 () ; // 建 立 实体 类 kcb 

27 kcb. kch = txtkch. Text. Trin(); // 控 件 菠 续 邓 实体 类 中 
283 kcb. kcn = txtKcm- Text. Trim() ; 

299 kcb. xuefen = Corwert. ToTInt32(txtXf. Text. Trim()) 

30 kcb. kkdw = txtKkdw.Text.Trint) ; 

31 册 . 课 程 表 . InsertOnSubmit (kcb) ; /7 把 插入 的 数据 插 到 db 
32 db. SubnitChanges () ; // 更 新 后 台数 据 库 

34 var result = from r in db. 课 程 表 where r,kch == txtkch. Text select r; 
359 gvkcb. DataSource = result 

369 gvkcb. DataBind() ; 

37 } 

38 } 

S91-} 


7-7 以 LINQ 实 现 记 录 插 入 的 C# 代 码 


学 生 选 课 情况 查询 


请 选择 学 生 的 所 在 单位 ， 站 “- 国 


S001 |]K002 热学 20111/1000000 


S002 |K002 。 | 类 学 j2otmmoooooo 


7-8 以 LINQ 实现 多 表 连 接 查 询 的 最 终 效 果 图 


(2) 从 [工具 箱 ] 的 [标准 ] 栏 目下 拖 动 一 个 DropDownList 控件 到 窗 体 中 ,修改 其 ID 为 
ddIDw。 然 后 从 [工具 箱 了 的 【标准 了 栏目 下 拖 动 一 个 Button 放 到 DropDownList 后 面 ,修改 
Button 的 ID 为 btnFind, Text 值 为 "查找 ?。 最 后 从 【工具 箱 了 的 【数据 ] 栏 目下 拖 动 一 个 
GridView 到 窗 体 的 适当 位 置 , 修 改 其 ID 为 gvZhb。 

(3) 双击 【查找 按钮 ,进入 C# 代 码 设计 状态 ,为 btnFind_Click 方法 编写 代码 。 最 终 
得 到 的 程序 语句 如 图 7-9 所 示 ( 此 处 忽略 了 若干 个 using 语句 ) 。 

3) 补充 说 明 

(1) 本 程序 专门 采用 手工 为 DropDownList 对 象 赋予 选项 的 方式 , 即 程序 第 24 一 29 行 。 
程序 首先 清空 了 DropDownList 对 象 的 原 有 选项 ,然后 执行 LINQ 查询 把 课程 表 中 的 课程 
号 和 课程 名 查找 出 来 , 保存 到 记录 集 对 象 res 中 ,然后 把 res 中 的 每 条 记录 都 添加 到 
DropDownList 对 象 的 选项 中 。 

(2) 本 程序 的 输出 结果 涉及 多 张 表 , 因 此 使 用 了 两 表 连 接 操作 。 第 36 行 体现 了 数据 来 
源 于 两 张 表 ,而 且 表 记录 的 别名 为 +r 和 x; 第 37 行 则 说 明了 连接 条 件 ; 第 38 行 是 普通 的 查 
询 条 件 ; 第 39 行 的 select 语句 指明 了 最 终 的 输出 结果 
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14 浊 mnamespace MyLINA 
15:| { 


16i public partial class WultiTable : System. YWeb.UI.Page 

mydbDataContext db = new mydbDataContext():; 

protected void Page Load(object sender，Evertargs e) 
坟 (lIsPostBack) 


ddlDw. Itens. Clear (); /清空 DropDownList 的 选项 
var res = from r in db. 课 程 表 select new { r.kch, r.kcn }; 


Hi (var xx in res) // 对 于 课程 表 中 的 每 个 记录 


ddlDw, Itens. Add (new ListIten(xx, kcn, xx,kch)); 
} Z/ 添 加 到 DropDowmList 的 选项 中 
| 
} 


protected void btnFind Click(object sender, Eventhres e) 
{ 


Response. Write (ddlDw. SelectedValue) ; 
var result = from r in 由 .课程 表 join x in 同 ,成 绩 表 // 多 表 连 接 
on r.kch equals x.kch // 连 接 条 件 
Where r.kch == ddlDw. SelectedValue 
Select new {x.xh,r.kch,r.kcm, x.score, x.kstime }; 
gvIihb. DataSource = result; // 查 询 结 果 送 GridYiew 
gvIihb. Dat aBind() ; V/ 刷 新 显示 


1 


图 7-9 以 LINQ 实 现 多 表 连 接 查 询 的 代码 


4. 数据 分 组 计算 程序 

1) 案例 要 求 

使 用 LINQ 技术 编写 程序 ,能 够 计算 出 每 个 单位 的 学 生 获 得 奖学金 的 总 额 和 学 生 的 人 
数 。 要 求 上 部 的 GridView 中 显示 出 学 生 的 信息 ,下 部 的 GridView 中 分 单位 显示 学 生 人 数 
和 学 生 获得 奖学金 总 额 ,要 求实 现 的 界面 如 图 7-10 所 示 。 


学 生 名 单 情况 
学 生 间 


# 日 姓名 性 别 E 
张 举 军 生物 系 
张 产 志 物理 系 
李 大 源 教育 系 
刘 明 物理 系 
在 而 丽 教育 系 


刘 明 教育 系 


123 


分 单位 的 学 生 人 数 和 获奖 学 金 总 额 ， 


图 7-10 以 LINQ 实现 分 组 计算 查询 的 最 终 效果 图 
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2) 设计 过 程 

(1) 新 建 Web 窗 体 , 命 名 为 StuJl。 在 其 【设计 了 视图 下 ,首先 利用 表格 进行 简单 的 页 面 
布局 ,并 输入 提示 文字 “学 生 名 单 人 情况”“ 学 生 名 单 : ”和 “分 单位 的 学 生 人 数 和 获奖 学 金 总 
额 :”, 适 当 设置 文字 的 外 观 。 

(2) 首先 ,从 [工具 箱 了 的 【数据 ] 栏 目下 拖 动 一 个 GridView 控件 到 窗 体 中 ,修改 其 ID 为 
gvXsb。 然 后 从 [工具 箱 ] 的 [标准 ] 栏 目下 拖 动 一 个 Button 控件 放 到 中 部 的 文字 后 面 ,修改 
Button 的 ID 为 btnCal,Text 值 为 “分 单位 计算 ”。 最 后 从 【工具 箱 ] 的 [数据 ] 栏 目下 拖 动 一 
个 GridView 到 窗 体 的 适当 位 置 ,修改 其 ID 为 gvXshz。 

(3) 双击 【分 单位 计算 按钮 ,进入 C# 代 码 设计 状态 ,为 初始 化 程序 Page_Load 方法 和 
btnCal_Click 方法 编写 代码 。 最 终 得 到 的 程序 语句 如 图 7-11 所 示 ( 此 处 忽略 了 若干 个 
using 语句 ) 。 


149 namespace MyLINQ 

有 2 public partial class StuJl : Systemn.Web.UI.Page 

18 mydbDataContext db = new mydbDataContext () : 

20i void showdata() // 定 义 一 个 显示 数据 的 函数 showdata 
22 Var res = fron r in db. 学 生 表 // 执 行 LIMQ 查 鹿 表 达 式 
引 orderby r.xh 


select new 


xh, // 显 示 为 中 文 标题 


录 扫 隆隆 眉 
版 也 站 前 由 


31 全 
32 gVXsb, DataSource = res; 
33 gwXsb.Datapind() : 

] 


36 扣 protected void Page_Load(object sender, EventAres e) 
38j if (lIsPostBack) /1 如果 是 首次 进入 本 页 
40 showdata() ; /显示 学 生 名 单 

42 上 】 

44 昌 有 void btnCal_Click(object sender, EventArgs e) 


463 var rs = from r in 出 .学生 表 // 执 行 一 个 分 组 查询 

a7! group r by r. dwei into g 

48 select new 

49 { 单位 =g.Key, 人 数 =g.Count (), 总 金额 =g.Sum (p=>p. jlje) }: 
50; gVXshz.DataSource = rs; 

51i gvXshz. DataBindO) ; 

52i[- } 


54 浊 protected void gvXsb_PageIndexChanging (object sender, GridYiewPageEventhrgs 
{ 


56 gvXsb.PageIndex = e.NewPageIndex;  // 执 行 翻 页 功能 
57 showdata() ; 
} 


60 和 所 protected void gvisb_SelectedIndexChanged(object sender, Eventhres e) 
{ 


7-11 以 LINQ 实现 分 组 计算 查询 的 C# 代 码 
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3) 补充 说 明 

(1) 为 保证 显示 学 生 名 单 的 gvXsb 支持 翻 页 功能 ,本 程序 专门 定义 了 一 个 函数 show- 
data, 此 函数 负责 执行 查询 并 把 查询 结果 赋予 gvXsb 控件 。 此 函数 供 页 面 初始 化 和 翻 页 时 
调 月 


(2) 本 程序 在 btnCal_Click 的 方法 中 设计 了 一 个 支持 分 组 查询 的 LINQ 语句 ,是 本 实 
例 的 重点 和 难点 。 


1.3 基于 LINO 的 程序 实例 


下 面 将 通过 3 个 例子 说 明 借助 于 LINQ 技术 的 开发 过 程 。 在 下 面 的 例子 中 ,假设 项 目 
MyLINQ 已 经 创建 ,并 且 在 项 目 MyLINQ 中 添加 了 一 个 关于 数据 库 “ 学 生 管 理 (XSGL)” 的 
名 字 为 mydb 的 LINQ to SQL 类 。 


7.3.1 基于 LINO 技术 的 级 联 程序 


1) 案例 要 求 

设计 如 图 7-12 所 示 的 Web 程序 ,上 部 的 GridView 中 显示 学 生 表 的 基本 信息 。 当 单 击 
上 部 GridView 中 的 某 个 记录 后 ,将 在 下 部 的 GridView 中 显示 出 这 名 学 生 选 修 课 程 的 课程 
号 .课程 名 ,考试 成 绩 、 考 试 时 间 、 学 分 ,并 在 成 绩 单 的 上 部 显示 出 这 名 学 生 的 学 号 .姓名 、 
单位 。 


性 别 单位 


选择 Al00 张 匠 军 女 生物 系 
选择 S001 张 涯 志 女 物理 系 
选择 S003 刘 明 女 物理 系 
选择 S004 奉 丽 而 女 教育 系 
选择 S005 刘 明 男 教育 系 


K001 力学 4 94 2012/12/12 0:00:00 


K002 ”热学 3 85 2011/1/10 0:00:00 
K003 ”教育 心理 学 3 71 2011/1/14 00000 


图 7-12 以 LINQ 实现 级 联 查询 的 最 终 效 果 图 


2) 设计 过 程 

(1) 新 建 Web 窗 体 ,命名 为 StuScor。 在 其 设计 视图 下 ,首先 利用 表格 进行 简单 的 页 面 
布局 ,并 输入 提示 文字 “学 生成 绩 显示 ”和 中 部 的 “学 生 学 号 :"“ 学 生 姓名 :” 和 “学 生 单位 :”， 
适当 设置 文字 的 外 观 。 
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(2) 首先 ,从 [工具 箱 ] 的 [数据 栏目 下 拖 动 一 个 GridView 控件 到 窗 体 中 ,修改 其 ID 为 
gvXsb。 然 后 再 从 【工具 箱 ] 的 [数据 ] 栏 目下 拖 动 一 个 GridView 到 窗 体 的 适当 位 置 ,修改 其 
ID 为 gvCjb。 

其 次 ,利用 GridView 智能 菜单 的 [自动 套用 格式 】, 分 别 为 两 个 GridView 选择 恰当 的 
外 观 ; 然后 ,利用 智能 菜单 的 [编辑 列 ] 功 能 ,为 gvXsb 增加 一 个 “选择 ” 列 。 

最 后 ,通过 【属性 面板 ,为 gvXsb 设置 AllowPaging 为 true、PageSize 的 值 为 6， 
DataKeyNames 为 “学 号 ”。 

(3) 在 选中 gvXsb 的 状态 下 , 单 击 【属性 ] 面 板 的 “方法 ”( 国 | ) 按 钮 ,打开 方法 状态 。 分 
别 双 击 其 SelectedIndexChanged 和 PagelndexChanging ,为 这 两 个 事件 在 cs 文档 中 添加 对 
应 的 方法 (gvXsb_SelectedIndexChanged 和 gvXsb_PageIndexChanging) 。 

最 后 ,进入 C# 代 码 设计 状态 ,为 初始 化 程序 Page_Load 方法 和 新 创建 的 两 个 方法 编写 
代码 。 最 终 得 到 的 程序 语句 如 图 7-13 所 示 。 


7.3.2 基于 LINO 技术 的 记录 批量 处 理 程 序 


1) 案例 要 求 

设计 如 图 7-14 所 示 的 Web 程序 ,要 求 在 最 左 侧 有 一 列 复 选 框 , 用 户 可 以 通过 复 选 框 选 择 
记录 。 对 于 选中 的 记录 ,如 果 单 击 底部 的 【批量 删除 } 按 钮 , 则 可 以 把 选中 的 记录 全 部 删 掉 。 

2) 设计 过 程 

(1) 创建 窗 体 文档 

新 建 Web 窗 体 ,命名 为 XsDelete。 在 其 [设计 3 视图 下 ,首先 利用 表格 进行 简单 的 页 面 
布局 ,并 输入 提示 文字 :“ 利 用 LINQ 批量 删除 学 生 ”, 并 适当 设置 文字 的 外 观 。 其 次 ,从 [ 工 
具 箱 中 [标准 ] 栏 目下 拖 动 一 个 Button 控件 放 到 底部 ,命名 为 btnDelete, 修 改 Text 属性 为 
“批量 删除 ”。 

(2) 创建 GridView 并 优化 

首先 ,从 [工具 箱 ] 的 [数据 栏目 下 拖 动 一 个 GridView 控件 到 窗 体 中 。 通 过 【属性 】 面 
板 ,修改 其 ID 为 gvXsb ,为 gvXsb 设置 AllowPaging 为 true、PageSize 的 值 为 6。 

其 次 ,利用 GridView 智能 菜单 的 [自动 套用 格式 】 ,为 GridView 选择 恰当 的 外 观 ; 然 
后 ,利用 智能 菜单 的 [编辑 列 ] 功 能 ,为 gvXsb 增加 一 个 Template 列 ,设置 列 的 HeaderText 
为 “删除 记录 ”。 

最 后 ,利用 GridView 智能 菜单 的 [编辑 模板 】, 为 Template 的 ItemTemplate 区 域 添加 
一 个 CheckBox 控件 ,并 命名 为 CK。 

(3) 修改 cs 程序 代码 

双击 按钮 “批量 删除 ”, 进 入 到 XsDelete. aspx. cs 的 编辑 状态 ,为 初始 化 程序 Page_Load 
方法 和 btnDelete_Click 方法 编写 代码 。 最 终 得 到 的 程序 语句 如 图 7-15 所 示 。 


7.3.3 基于 LINO 技术 的 记录 编辑 程序 


1) 案例 要 求 
设计 如 图 7-16 所 示 的 Web 程序 ,能 够 对 选中 的 记录 进行 编辑 。 要 求 以 GridView 方式 
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显示 学 生 表 的 信息 , 当 用 户 单 击 【选择 编辑 ] 超 链接 时 ,程序 会 把 选中 的 记录 的 详情 显示 在 底 
部 的 Web 控件 里 ,并 请 用 户 进行 编辑 , 单 击 底部 的 [保存] 按钮 ,可 把 编辑 后 的 数据 保存 
下 来 。 


149 namespace MyLINA 

{ 
public partial class StuScor ; System,YWeb.UI,Page 
{ 


mydbDataContext db = new mydbDataContext ():; 
void showData() { 
var res = from r in 由. 学 生 表 
orderby r.xh 
select neV 


r.xh, 
r. Xn, 
r.xb, 
r. dwei 


i 
gviXsb. AllowPaging = true; 
gvisb. PageSize = 
gvisb.DataSource = resi 
gvisb. DataBind() ; 


. 


protected void Page_ Load(object sender, Eventhrgs e) 


if (lIsPostBack) showData(); 


395 protected void gvRsb_SelectedIndexChanged(object sender, Eventirgs e) 
M0 
Ml String Xsxh=gwXsb. SelectedYalue. ToString (). Trin(); 
42 var rs = from r in 同 .成 绩 表 
M3 join x in 由 .课程 表 
ad: on r,kch equals x.kch 
5 where r.xh == xsxh 
46 select new 
7 
I48 课程 号 = r, kch, 
49 课程 名 = x,kcm 
50 学 分 = x,xuefens 
51 考试 成 绩 = r. score, 
52 考试 时 间 = r.kstime 
53 人 
54 gwCjb.DataSource = rs; 
55 gwCjb.Databindf) ; 
56 
T var xsrs = from + in 曲 .学 生 表 where r.xh == xsxh select r; 
58 Var xs=xsrs. First () ; 
59 1blXh. Text = Xs.xh' 
60 ]blXm. Text = xs.xm; 
61 lblDw. Text = xs, dwei; 
62: 
63 夺 } 
64 
6566 和 protected void gvisb_PageIndexChanging (object sender, GridVYiewPageEventArgs 
66 
67: evisb. PageIndex = e.NewPageIndex:; 
68 showDatal) ; 
69 } 
70 ] 
Tt} 


7-13 以 LINQ 实现 级 联 查询 的 C# 代码 
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利用 LINQ 批 量 删除 学 生 


1997/U1 00000 ”生物 系 生物 史 。 12345678 。 200 


a Al00 张 荐 军 女 

日 S001 张 萍 志 女 1989/12/1 00000 ”物理 系 ”物理 学 687091234 900 

S002 李 大 源 男 1990/1/120.0000 教育 系 教育 中 。 687991234 0 

S003 刘 明 。 女 19904/12 00000 ”物理 系 ”物理 学 698721212 100 

S004 ”在 丽 责 女 1991/1/100000 。 教育 系 学 前 教育 698712345 400 

S005 刘 明 男 教育 系 100 
123 


图 7-14 以 LINQ 实现 记录 批量 处 理 的 最 终 效果 图 


14 浊 namespace MyLINA 

i 
public partial class XsDelete : System.Web.UI,Page 
{ 


mydbDataContext db = new mydbDataContext () ; 


void shovData() { /1 新 定义 的 显示 学 生 表 信 息 的 函数 
var res = from r in 由 .学 生 表 orderby r.xh select r; //LINQ 语 句 ， 获 得 数据 
gvksb. DataSource = res; // 记 录 集 绪 定 到 GridYiew 上 


gwXsb.Datapind() ; 
} 


protected void Page_Load(object sender, Eventhres e) 


过 (IIsPostBack) showData();  // 首 次 进入 本 网 页 ， 显示 学 生 表 内 容 


protected void btnDel_Click(object sender, Eventh e) // 响 应 按钮 的 Click 事 件 
{ 
Wow gvr in gvXsb.Rovs) /1 对 GridYiew 逐 条 记录 处 理 


foreach (Gr 


String xsxh = gvr.Cells[1].Text. Trim():; 

/1 获取 当前 行 第 2 列 的 
CheckBox ck = gvr.FindControl("ck") as Che 
if (ck.Checked) 


| 
Var xres = fron r in db, 学 生 表 where r.xh == xsxh select r; 
同 , 学 生 表 .Deletehl10nSubmit (xres);  // 在 DataContext 执 行 暗 除 语句 
} 
} db. SubmitChanges(); showData() ; 1/ 更 新 后 台数 据 库 ， 别 新 显示 


} 


protected void gvXsb_SelectedIndexChanged(object sender, Eventhrgs e) 
[| 


protected void gvisb_PageIndexChanging (object sender, GridViewPageEventhres e) 
#7 响应 翻 页 事件 | 
gvisb, PageIndex = e,NewPageIndex.; 
showData() ; 


图 7-15 以 LINQ 实现 记录 批量 删除 的 C# 代码 


2) 设计 过 程 

(1) 创建 窗 体 文档 

新 建 Web 窗 体 ,命名 为 StuEdit。 在 其 设计 了 视图 下 ,首先 利用 表格 进行 简单 的 页 面 布 
局 ,并 输入 提示 文字 “学 生 信 息 编辑 "和 “请 编辑 学 生 的 信息 ”, 并 适当 设置 文字 的 外 观 。 
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学 生 信 息 编辑 站 


选择 编辑 A100 张 萍 军 女 1997/1/100000 生物 系 ”生物 史 12345678 200 
选择 编辑 S001 张 萍 志 女 1989/12/1 00000 物理 系 物理 学 。687091234 900 
选择 编辑 S002 李 大 源 ? 男 1990/1/12 0:00:00 教育 系 教育 史 687991234 0 
选择 编辑 S003 ” 刘 明 ” 女 19904/12 00000 物理 系 ”物理 学 ”698721212 100 
选择 编辑 S004 看 丽 丽 女 1991/1/1 000:00 教育 系 学 前 教育 698712345 400 
选择 编辑 S005 刘 明 男 教育 系 100 3 

123 

请 编辑 学 生 的 信息 ， 

学 号 ,S002 姓名 ， 玫 大 和 2 
性 别 ， 男 生日 ，19901/12 0:00:00 
单位 ， 教育 系 专业 ， 教 育 史 
联系 电话 。 687991234 

[| 


图 7-16 以 LINQ 实 施 编 辑 指定 记录 的 最 终 效果 图 


(2) 创建 GridView 并 优化 

首先 ,从 [工具 箱 ] 的 [数据 栏目 下 拖 动 一 个 GridView 控件 到 窗 体 中 。 通 过 【属性 】 面 
板 修改 其 ID 为 gvXsb, 为 gvXsb 设置 AllowPaging 为 true、PageSize 的 值 为 6。 

其 次 ,利用 GridView 智能 菜单 的 【自动 套用 格式 ] 为 GridView 选择 恰当 的 外 观 ; 然后 ， 
利用 智能 菜单 的 【编辑 列 】 功 能 为 gvXsb 增加 一 个 “选择 ” 列 , 设 置 列 的 HeaderText 和 
SelectText 属性 都 是 “选择 编辑 "。 再 通过 【属性 面板 修改 此 GridView 的 DataKeyNames 
值 为 xh。 

注意 ; 要 使 用 “选择 ” 列 ,就 必须 为 GridView 声明 DataKeyNames 的 字段 名 称 。 

(3) 创建 数据 编辑 区 域 

在 窗 体 中 添加 一 个 Table 控件 ,适当 设置 其 行 数 和 列 数 。 然 后 在 其 中 添加 如 图 7-16 所 
示 的 控件 和 文字 。 把 Label 命名 为 lblXh, 其 他 的 文本 框 控件 依次 命名 为 txtXm txtXb、 
txtSr txtDw .txtZhy txtDh 。 

在 窗 体 底部 添加 一 个 Button 控件 ,命名 为 btnSave, 设 置 其 Text 属性 为 “保存 ”。 

注意 : 因 学 号 为 主键 ,其 值 不 允许 被 修改 ,所 以 学 号 对 应 的 控件 为 Label 型 控件 。 

(4) 添加 C# 代 码 

选择 gvXsb 控件 ,然后 单 击 【[ 属 性] 面板 上 的 [方法 按钮 ,使 [属性 ] 面 板 进入 “方法 ” 设 
置 状态 ,分 别 双 击 SelectedIndexChanged 和 PagelndexChanging ,在 cs 文档 中 添加 对 应 的 方 
法 ,并 为 这 两 个 方法 编写 代码 。 

双击 【保存 ] 按 钮 ,为 初始 化 程序 Page_Load 方法 和 btnSave_Click 方法 编写 代码 。 最 
终 得 到 的 程序 语句 如 图 7-17 所 示 。 

最 后 , 按 Ctrl 十 F5 键 运行 程序 ,检查 程序 的 执行 情况 。 
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1 pe NyLINA 

15 

16 汪 public partial class StuEdit : System. Web.UI.Page 

17 { 

18 mydbDataContext db = new mydbDataContext () ; 

19 

20 所 void showData() 

21 { /1 新 定义 的 显示 学 生 表 信 息 的 函数 

22 Var res = fron r in 山 . 学 生 表 orderby r,xh select r; //LIMA 语 句 ， 获 得 数据 
23 gvhsb. DataSource = res; /f/f 记录 集 绪 定 到 GridYiew 上 

24 gwXsb.DataBind() ; 

25 于 

269 protected void Page Load(object sender, Eventhrgs e) 

27 { 

289 这 (IIsPostBack) shovData() ;  // 首 次 进入 本 网 页 ， 显 示 学 生 表 内 容 

29 } 

30 

1 如 ea void btnSave_Click(object sender, EventAres e) 

32 

33 证 (txtXn. Text, Trin().Length == 0) // 对 输入 信息 进行 服务 器 油 验 证 

34 Response,Write("《Script>alert( 姓名 不 能 为 空 值 ! ' ) ;人 /Script>") ; 

35 // 使 用 JavaScript 提 示 框 警示 

36 if (txtXb, Text. Trim().Length == 0) 

37 Response. Write("《Script》alert ("性别 不 能 为 空 值 ! ') ;Script>”) ; 

38 if (txtDw, Text. Trim().Lengeth == 0) 

39 Response. Write("《<Script >alert(' 单位 不 能 为 空 值 ! ') ;人 /Script>") ; 

40 var res = from r in db. 学 生 表 where r.xh == lblXh. Text select ri; 

41 Yar rec = res.First(); /1 著 取 被 修改 的 记录 

42 rec. xm = txtXm. Text ; A/ 把 修改 后 的 值 存 入 Dat aCont ext 对 象 
43 char []xsxb = txtXb. Text. ToCharhrray () ;//String 型 转化 为 字符 数组 

44 rec.xb = xsxb[0] ; 

45 Tec, dwei = txtDw.Text 

46 rec. csdate =Convert.ToDateTime (txtSr. Text) ; //String 型 转化 为 日 期 时 间 型 
47 Tec. zhye = txtZhy. Text:; 

48 Tec,phone = txtDh. Text; lS 

EE db. SubmitChanges () ; // 新 数据 更 新 到 后 台数 据 库 

50 showData() ; /1 用 GridYiew 显 示 结果 

51 1 

53 和 protected void gvXsb_PageIndexChanging (object sender，GridViewPageEventhrgs e) 
54 7/ 响应 翻 页 事件 

55 gwXsb.PageIndex = e.NewPageIndex; 

56 showData() ; 

57 } 

58 

59 折 protected void gvXsb_SelectedImndexChanged(object sender, Eventhres e) 

60 { 

61 String xsxh = gvXsb. Selectedyalue.ToString() ; // 获 取 Gridyiew 的 选择 结果 
62 Var res = from r in db. 学 生 表 where r.xh == xsxh select r; 

63 Var rec=res.First (); // 得 到 被 选中 的 记录 

64 1blXh. Text = // 把 记录 值 送 到 对 应 的 媳 b 控 件 中 
65 txtXm。 Text = 

66 txtXb. Text = 

67 txtSr. Text = rec.csdate.ToString() ; 

68 txtDw. Text = rec. dwei; 

69 txtZhy. Text = rec. zhye; 

70 txtDh. Text = rec.phone; 

11 } 

72 } 

73|°} 


图 7-17 以 LINQ 实施 编辑 指定 记录 的 C# 代 码 


0.4 LINO 技术 其 他 应 用 简介 


除了 LINQ to SQL 技术 ,LINQ 体系 还 提供 了 面向 Object \ 面 向 XML 的 技术 。 下 面 将 
主要 对 LINQ to XML 的 技术 进行 简要 的 介绍 。 
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六 


4.1 LINO to XML 的 目的 和 关键 方法 


XML 文档 的 结构 是 众所周知 ,本 节 就 不 再 蓝 述 ,这 里 将 主要 就 LINQ 技术 针对 XML 
的 关键 类 定义 和 主要 方法 展开 说 明 。 


Ys 


LINO to XML 概述 


由 于 XML 文档 支持 树 状 结构 ,因此 在 描述 计算 机 软件 系统 配置 .进行 层次 结构 描述 方 
面具 有 关系 数据 库 难 以 比拟 的 优势 。LINQ to XML 技术 的 出 现 , 为 XML 文档 的 进一步 应 
用 提供 了 有 力 的 支持 。 

LINQ to XML 技术 提供 了 在 .NET 3. 5 编程 语言 中 对 XML 文档 进行 处 理 的 技术 , 它 
针对 XML 文档 结构 开发 了 新 的 对 象 模型 ,使 得 开发 者 可 以 把 XML 文档 保存 在 内 存 中 , 便 
利 地 操作 XML 类 型 的 数据 ,对 XML 数据 实施 插入 、 删 除 等 操作 ,甚至 可 以 使 用 查询 表达 式 
对 XML 文档 中 的 元 素 进行 检索 。 


2; 


LINO to XML 技术 概述 


LINQ to XML 也 是 一 个 复杂 的 技术 体系 ,但 比较 关键 的 类 和 操作 还 是 比较 容易 理解 
的 。 目 前 用 得 比较 多 的 类 如 下 : 


XDocument 类 一 一 用 于 声明 一 个 XML 文档 ,其 他 的 类 都 处 于 这 个 文档 的 内 部 。 
XDocument 类 有 一 个 非常 关键 的 方法 Save() ,其 作用 是 保存 XML 文档 。Save 方 
法 以 XML 文档 的 完整 名 称 作为 参数 ,要求 使 用 绝对 路 径 形式 。 

XDeclaration 类 一 一 用 于 表达 XML 文档 的 声明 信息 ,如 说 明 XML 文档 的 版 本 号 、 
编码 等 。 

XComment 类 一 一 用 于 为 XML 文档 添加 注释 信息 。 由 XComment 类 声明 的 信息 
被 包括 在 XHTML 的 注释 符号 “二! 一 ”一 二" 之 中 。 

XElement 类 一 一 用 于 定义 XML 文档 中 的 一 个 元 素 。XElement 对 象 可 以 多 重 帜 
套 , 从 而 实现 复杂 的 属性 体系 。 

XAttribute 类 一 一 用 于 定义 一 个 元 素 的 属性 , 它 是 一 个 “名 称 / 值 ”? 对 。XAttribute 
对 象 用 于 说 明 与 自身 最 邻近 的 外 层 XElement 对 象 的 属性 。 


3. XElement 类 
XElement 类 的 对 象 可 以 谤 套 ,用 多 层 小 括号 表示 元 素 之 间 的 层次 关系 。 其 关键 属性 和 
方法 如 表 7-2 所 示 。 
表 7-2 XElement 类 的 关键 属性 和 方法 
属性 /方法 名 作 用 
Name 获取 元 素 的 名 称 
Value 获取 元 素 的 值 
Attribute() 获取 元 素 的 属性 值 
SetAttributeValue( 值 ) 设置 元 素 的 属性 值 
load() 把 元 素 从 XML 文档 调 人 内 存 
Save() 把 元 素 保存 到 XML 文档 中 
Remove() 删除 元 素 


Add( 子 元 素 名 ) 向 本 元 素 中 添加 一 个 子 元 素 


第 7 章 LINQ 访 问 数据 库 “191 


4 


7.4.2 LINO to XML 的 应 用 示例 


1. 创建 XML 文档 

1) 案例 要 求 

要 求 创建 如 图 7-18 所 示 的 XML 文档 。 在 此 文档 中 ,把 学 校 各 个 单位 的 基本 信息 存储 
在 XML 文档 中 ,其 实质 是 用 XML 文档 存储 了 一 张 关 系 表 的 信息 。 


<?xml version="1.0" encoding="utf-8" ?> 
-< 学 校 单 位 > 
- < 直属 单位 ID=' 教 务 处 " 地 址 =" 主 楼 123"> 
< 单位 名 > 教务 处 </ 单 位 名 > 
< 负责 人 > 黎明 科 </ 负 责 人 > 
< 电话 >77992</ 电 话 > 
</ 直 属 单位 > 
- < 直属 单位 ID=" 财 务 处 " 地 址 =" 主 楼 124"> 
< 单位 名 > 财务 处 </ 单 位 名 > 
< 负责 人 > 张 志 兰 </ 负 责 人 > 
< 电话 >98762</ 电 话 > 
< 地 址 > 主楼 124</ 地 址 > 
</ 直属 单位 > 
- < 直属 单位 ID=" 科 研 处 " 地 址 =" 科 技 楼 128"> 
< 单位 名 > 科技 处 </ 单 位 名 > 
< 负责 人 > 刘 亦 云 </ 负 责 人 > 
</ 直属 单位 > 
</ 学 校 单位 > 


7-18 要 实现 的 XML 文档 的 最 终 效 果 


2) 设计 方法 

新 建 普通 Web 窗 体 ,在 窗 体 中 添加 一 个 创建 XML 文档 的 Button, 修改 其 ID 为 
btnCreateXML ,然后 为 此 按钮 编写 响应 Click 事件 的 C# 代 码 。 

利用 LINQ to XML 技术 ,设计 如 图 7-18 所 示 效 果 使 用 的 代码 如 图 7-19 所 示 。 

2. 查询 信息 

1) 案例 要 求 

针对 图 7-19 所 示 的 XML 文档 ,现在 假设 界面 上 有 一 个 文本 框 T1, 要 求 通过 T1 查找 
单位 名 称 为 T1 值 的 元 素 ,并 输出 与 此 单位 名 相关 的 负责 人 电话 等 信息 。 

2) 程序 代码 

利用 LINQ to XML 技术 编程 ,针对 【查询 按钮 btnFind 的 Click 事件 的 响应 方法 如 
图 7-20 所 示 。 

从 图 7-20 中 可 以 看 出 ,LINQ to XML 技术 支持 对 XML 文档 使 用 LINQ 的 查询 表达 
式 , 实 现 对 特殊 数据 的 查询 。 

3. 删除 指定 的 结 点 

1) 案例 要 求 

针对 图 7-19 所 示 的 XML 文档 ,现在 假设 界面 上 有 一 个 文本 框 T2 ,要 求 通过 T2 查 
找 单位 名 称 为 T2 值 的 元 素 , 并 把 与 该 元 素 相 关 的 信息 删除 ,然后 显示 此 XML 文档 的 
内 容 。 
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protected void btrnCreatexH Click(object sender, Eventhrgs e) 
{ 


String XILFn = Server. MapPath(" /NyXIL. xml"); 
XDocument doc = new XDocument () ; 

new XDeclaration("1.0","utf-8", "yes"): 

new XComment ("学 习 XL 文档 "); 


本 
单位 
单位 


Element zong=new XElement (" 学 校 单 
Elenmert Ajwc = new XElenent ("直属 
NElenent Acwc = new XElenent ("直属 
XElement Akyc = new XElement(" 前 必 单位") 


Xattribute AjwcID = new XAttribute ("ID", " 
XAttribute AcwcID = new XAttribute ("ID", 
XAttribute AkycID = new XAttribute ("ID", 


XAttribute AjwcDZ = new XAttribute ("地址 ", 
Xattribute AcwcDZ = new XAttribute ("地址 ", 
XAttribute 上 ycDZ = new Xttribute ("地址 "科技 楼 128") ; 


XElenent Ajwcl = new XElement ("单位 名 ", "教务 处 ") ; 
中 lemnent hjwc2 = new RElement ("负责 人 ",， "黎明 科 "); 
XElenent Ajwc3 = new XElement ("电话 ",，"77992"); 


XElenent Acwcl = new XElement "单位 名 "，" 财 务 处 ") ; 
XElement Acwc2 = new XElement (" 负 责 人 "，" 张 志 兰 ") ; 
XElenert Acwc3 = new XElement (" 电 话 "， ?98762" ); 

XElenent Acwc4 = new XElenent ("地 址 "，" 主 楼 124") ; 


XElenent Akycl = new XElement (单位 各。 "科技 处 ") ; 
XElenert Akyc2 = new XElenent (" 负 责 人 "，" 刘 亦 云 ") ; 
XElenent Akyc3 = new XElenent (" 电 话 "， “92381") ; 


doc. Add (zong) ; 
zong. Add(Ajwc) ; zong. Add(Acwc) ;zong. Add(Akyc); 


Ajwc, Add (AjwcID); Ajwc. Add(AjwcDZ) ; 
Ajwc. Add(Ajwc1) ; Ajwc, Add(Ajwc2), Ajwc. Add(Ajwc3); 


Bcwc. Add(AcwcID) ; Acwc. Add(AcwcD?) ; 
Acwc. Add(Acwc1); Acwc. Add(Acwc2); Acwc,. Add(Acwc3) ;Acwc, Add(Acwcd); 


Akyc. Add (AkycID) ; Akyc. Add(AkycD7); 
Akyc. Add (Akyc1) ; Akyc. Add(Akyc2) ; 
doc. Save (XMLFn) ; 

Response. Redirect (" /MyXIL. xml"); 


图 7-19 以 LINQ 实 施 XML 文档 的 C# 代 码 


protected void btnFind Click (object sender, Eventhrgs e) 
{ 


String XILFn = Server, MapPath(" /WyXIL, xml") ; 

XElement xxjg = XElenent.Load(XILFn) ; 77 装 入 ZL 文件 

String node = Tl1. Text. Trim(); 的 

var xmlnode=from el in xxjg.Elenents(" 直 属 单 
Where (String)el.Elenent ("单位 
select el; /1 执行 查询 

foreach (XElenent ele im xnlnode) /显示 结果 

{ Response. Write (ele. Element ("单位 名 "). Yalue+" "); 

Response. Write(ele.Element ("负责 人 ").Yalue + " "); 

Response. Write(ele. Element ("电话 "). Yalue + "br/> ") ; 

} 


7-20 以 LINQ 实 现在 XML 文档 中 查询 信息 的 C# 代码 
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2) 命令 代码 
利用 LINQ to XML 技术 编程 ,针对 【查询 ] 按 钮 btnDel 的 Click 事件 的 响应 方法 如 
图 7-21 所 示 。 


8 入 protected void btnDel_Click(object sender，Eventargs e) 

88 { 

89 String XILFn = Server. NapPath(" /JICL. xml"):; 

90 XElenent xxjg = XElenert,Load(XILFn) ;77 装 入 XIL 文 件 

91 String node = T2. Text. Trin(); // 获 得 要 查询 的 名 称 
92 var xmlnode = from el in xxjg.Elenents(" 直 属 单位 ") 

93 where (5tring)el.Elenent ("单位 名 ") == node 
94 select el; // 执 行 查询 

95: foreach (XElenernt ele in xmlnode) // 逐 个 元 素 进 行 果 除 
96 { 

97 ele. Remove() ; // 执 行 删 除 语句 ， 把 ele 结 点 删除 

98 } 

99 xxjg. Save (XLFn) ; 

100 Response. Redirect (” /tyXIL. xml1") ; // 回 显 暗 除 后 的 结果 

101 


7-21 以 LINQ 实 现在 XML 文档 中 删除 元 素 的 C# 代 码 


4. 在 指定 结 点 中 插入 元 素 
1) 案例 要 求 元 素 名 称 ， 
针对 图 7-19 所 示 的 案例 ,假设 界面 上 有 | 后 和 位置 ， 
三 个 文本 框 ,分 别 为 txtName、txtValue 和 
txtPos, 分 别 表示 元 素 名 称 、 元 素 的 值 和 新 元 


es 图 7-22 以 LINQ 向 XML 文档 中 新 增 元 素 的 
素 的 插入 位 置 。 插 入 元 素 完毕 ,显示 此 XML 界面 效果 图 


文档 的 内 容 , 界 面 效 果 如 图 7-22 所 示 。 


2) 命令 代码 
利用 LINQ to XML 技术 编程 ,针对 【 插 和 元素] 按钮 btnIns 的 Click 事件 的 响应 方法 
如 图 7-23 所 示 。 


103 折 protected void btnIns_Click(object sender, Eventhres e) 

104 { 

105 String XMLFn = Server. MapPath(" /JI7XIL.xnl ) ; 

106 XElemert xxjg = XElenent.Load(XILFn) ; 7/ 装 入 ML 文件 _ 
107 String node = txtPos.Text.Trin() ; /获得 要 查询 的 名 称 
108 war xmlnode = from el in xxjg.Elenents(" 直 属 单位 ") 

109 Where (5tring)el.Element ("单位 名 ") == node 
110 select el; /执行 查询 

111 if (xnlnode.Count() == 0) /1 插入 位 置 判 定 
112 Response. Write("<Script>alert(' 插 入 位 置 不 存在 ') ;《/script>") ; 
113 else { 

114 XElenent pnode = xmlnode.First(); ”// 获 取 插 入 位 置 
115 String nodeName = txtName. Text. Trim():; 

116 String nodeValue = txtVyalue.Text.Trin() : 

117 XElenent nNode = new XElement (nodeNane, nodeYalue); 
118 V/ 产 生 新 元 素 

119 pnode. Add (nNode) ; // 新 元 素 插 入 

120 XXjg,. Save (XMLFn) ; // 保 存 结果 

121 Response,Redirect (”/JfyXJL. xnl") : 7/ 回 显 插入 后 的 效果 
122 

| } 

124 上 上 


图 7-23 以 LINQ 实 现在 XML 文档 中 插入 元 素 的 C# 代 码 
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Cs 结语 


LINQ 技术 是 .NET 3. 5 推出 的 技术 , 深 受 Microsoft 的 推崇 ,把 它 作 为 数据 处 理 的 主要 
推荐 标准 。 事 实 上 ,LINQ 技术 确实 在 简化 数据 处 理 语句 的 书写 .集成 面向 对 象 程序 设计 与 
数据 库 操作 ,提升 开发 效率 方面 发 挥 了 重大 作用 。 因 此 ,有 志 于 从 事 信 息 系统 和 动态 网 站 开 
发 的 人 员 ,应 该 在 LINQ 技术 领域 进一步 钻研 。 特 别 是 针对 LINQ to SQL 的 复杂 使 用 , 具 
有 广阔 的 应 用 前 景 。 


假 考题 


1. 什么 是 LINQ? 这 种 技术 有 什么 特点 ?针对 不 同类 型 的 数据 ,主要 有 哪些 具体 的 
LINQ 类 ? 

2. 什么 是 DataContext 类 ?什么 是 实体 类 ? 

3. 如 何在 项 目 中 增加 LINQ to SQL 类 ? 如 何在 DataContext 中 增加 实体 类 ? 

4. LINQ 使 用 什么 类 型 来 描述 记录 集 和 记录 ? 

5. LINQ 中 查询 表达 式 的 一 般 结构 是 什么 ?在 LINQ 查询 语句 中 ,为 什么 把 from 语 
句 放 在 了 语句 的 开始 处 ”查询 表达 式 通常 以 什么 语句 结尾 ? 

6. 如 果 把 LINQ 的 查询 结果 作为 GridView 的 数据 源 ,这 个 数据 源 是 否 支 持 无 代码 的 
自动 分 页 和 无 代码 删除 技术 ?如 果 不 支持 ,应 该 怎么 做 ? 

7. 在 LINQ 体系 中 ,是 如 何 实现 数据 插入 操作 的 ? 在 执行 InsertOnSubmit( 新 记录 ) 方 
法 后 ,还 需要 执行 什么 命令 ? 

8. 在 LINQ 体系 下 是 如 何 实现 记录 删除 操作 的 ? 方法 DeleteOnSubmit 与 方法 Delete- 
AllOnSubmit 有 什么 区 别 ? 

9. 在 LINQ 技术 中 ,如 何 实现 两 个 表 的 连接 操作 ? 

10. LINQ 支持 XML 文档 吗 ? XElement 类 的 作用 是 什么 ? 


仁 机 实 训 惠 


基于 第 5 章 创建 的 “商品 销售 系统 数据 库 ”, 新 建 商品 销售 项 目 SPLINQ ,在 此 项 目 中 利 
用 LINQ 完成 以 下 操作 。 

(1) 新 建 商 品 信息 管理 窗 体 ShangPin, 在 其 中 添加 GridView 控件 ,重点 显示 商品 信息 
的 前 4 个 字段 ,并 为 GridView 添加 * 选 择 ? 列 “删除 ? 列 。 设 置 GridView 为 自动 分 页 模式 ， 
每 页 显示 6 条 记录 。 

(2) 利用 “选择 ” 列 可 以 选 定 一 种 商品 ,并 用 ASP.NET 的 标准 控件 显示 出 被 选 定 商品 
的 详细 信息 ; 或 者 使 用 DetailsView 控件 显示 被 选 定 商品 的 详细 信息 。 

(3) 利用 “删除 ? 列 的 按钮 ,可 以 把 被 单 击 的 商品 删除 ,而且 要 求 在 真正 地 执行 删除 命令 
前 先 要 核实 “您 确实 想 删 除 这 种 商品 吗 ?”; 只 有 客户 确实 选 定 为 “是 ”, 才 可 使 用 LINQ 技术 
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把 该 商品 删除 。 

(4) 利用 模板 列 ,为 GridView 添加 TextBox 列 , 重 新 批量 输入 每 种 商品 的 进货 价 , 并 
及 时 地 返 存 回 商品 数据 库 的 商品 表 中 。 

(5) 不 使 用 FormView 技术 ,而 是 直接 使 用 标准 控件 编写 商品 信息 输入 界面 ,然后 利用 
为 LINQ 技术 实现 商品 信息 的 插入 。 

注意 : 在 使 用 LINQ 十 GridView 技术 管理 数据 库 的 过 程 中 ,由 于 后 台数 据 库 与 
GridView 的 绑 定 并 不 十 分 密切 ,要 注意 在 GridView 翻 页 或 后 台数 据 库 更 新 时 ,必须 做 好 
GridView 控件 的 界面 刷新 问题 。 


以 SqlConnection 访 问 数据 库 


学 习 要 点 

本 章 主要 学 习 ASP .NET 访问 数据 库 的 传统 技术 ,主要 讲授 基于 SqlConnection 的 
SqlCommand 技术 和 SqlDataAdapter 技术 ,并 对 ASP.NET 访问 数据 库 中 的 关键 概念 进行 
了 系统 的 梳理 。 本 章 要 求 重点 关注 以 下 内 容 : 

。 SqlCommand 和 SqlDataAdapter 技术 访问 数据 库 的 技术 体系 。 

。 DataSet、DataTable、DataView、DataReader 的 概念 及 其 相互 转化 方法 。 

。 数据 表示 层 控件 GridView、DataGrid、FormView、DataList、ListView 的 用 法 、 基 本 

配置 。 


@. 1 基于 SqlCommand 访问 数据 库 


8.1.1 SqlCommand 技术 简介 


1. 什么 是 SqlCommand 

从 Microsoft 系列 开发 工具 访问 数据 库 的 发 展 看 ,通过 执行 嵌入 式 SQL 语言 进行 数据 
库 访 问 是 最 初 的 技术 。 在 这 个 体系 下 ,开发 工具 提供 的 可 用 控件 较 少 , 绝 大 多 数 的 工作 都 必 
须 由 开发 人 员 完 成 。 也 正 是 基于 此 ,利用 SqlCommand 访问 数据 库 的 技术 方案 非常 简单 ， 
主要 涉及 创建 数据 库 连 接 .执行 嵌入 式 的 SQL 命令 ,获得 执行 结果 三 个 内 容 。 至 于 其 他 工 
作 ,都 必须 由 开发 人 员 编 程 实现 。 

从 当时 的 技术 需求 看 ,为 适应 不 同 的 数据 库 连 接 要 求 , 提 出 了 适应 不 同 数据 库 类 型 的 
Connection( 连 接 ) 类 和 Command( 命 令 ) 类 ,如 连接 Access 数据 的 OleDbConnection .连接 
SQL Server 数据 库 的 SqlConnection 等 。 尽 管 种 类 繁多 ,但 仅仅 是 语法 的 差异 ,使 用 方法 基 
本 相同 ,本 书 主要 以 连接 SQL Server 数据 库 为 例 ,对 相关 技术 进行 简要 的 介绍 。 

2. SqlCommand 访问 数据 库 的 技术 体系 

从 SqlCommand 访问 数据 库 的 方法 看 ,其 技术 体系 比较 清晰 。 相 关 控件 及 其 结构 如 
图 8-1 所 示 。 

从 图 8-1 中 可 知 ,在 利用 SqlConnection 对 象 建立 数据 库 连 接 的 基础 上 ,把 SQL 语句 以 
字符 串 的 形式 赋予 SqlCommand 的 CommandText 属性 ,然后 由 SqlCommand 对 象 执行 ,或 
者 直接 把 SQL 语句 提交 给 SqlCommand 对 象 执行 。 
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如 果 用 户 提 交 的 SQL 语句 是 一 条 查询 语句 (Select) , 则 需要 使 用 ExecuteReader 来 执 
行 ,执行 结果 是 一 个 只 读 的 记录 集 对 象 ee 
ConnectionString= 


DataReader。 开 发 者 可 以 从 DataReader 中 
获取 数据 ,进行 显示 或 其 他 处 理 。 
CommandText= 


如 果 用 户 提 交 的 SQL 语句 是 一 条 更 新 
语句 (Insert、Update 或 者 Delete) , 则 不 需要 
返回 记录 集 对 象 ,需要 用 ExecuteNonQuery 


ExecuteNonQuery ExecuteReader 


ExecuteNonquery 


来 执行 。 更 新 数据 
由 于 Microsoft 为 SqlConnection 和 Read( )| |getvalue 
SqlCommand 提供 了 多 种 结构 的 重 载 ,因此 数据 查询 
其 命令 参数 的 书写 有 多 种 形式 。 图 8-1 以 SqlCommand 访问 数据 库 的 
注意 ; 因 .NET 3.5 推荐 使 用 DataSource 技术 体系 示意 图 


和 LINQ 技术 ,默认 的 开发 环境 已 经 不 支持 SqlCommand 和 SqlConnection 控件 ,所 以 需要 
在 C# 代 码 的 开始 部 分 添加 引用 命名 空间 的 语句 “using System. Data. SqlClient; ”。 


8.1.2 SqlCommand 相关 技术 简介 


1. SqlConnection 控件 

1) SqlConnection 控件 的 目的 

SqlConnection 控件 是 数据 库 连 接 控 件 , 主 要 目的 是 创建 一 个 指向 特定 数据 库 的 数据 
连接 。 本 控件 需要 开发 者 提供 准确 的 连接 字符 串 , 用 以 说 明 被 连接 数据 库 的 详细 信息 。 


本 控件 的 执行 结果 是 获得 一 个 可 用 的 数据 连接 对 象 。 当 然 , 如 果 连 接 失败 , 则 获得 
null 值 。 

2) SqlConnection 控件 的 使 用 形式 

(1) 方式 一 


SqlConnection < 连接 名 > = new SqlConnection( 连 接 字 符 串 ); 
< 连接 名 >. 0pen( ) 


(六 专 式 二 


SqlConnection < 连接 名 > = new SqlConnection(); 

< 连接 名 >. ConnectionString = 连接 字符 串 

< 连接 名 >. 0pen( ) 

3) 连接 字符 串 的 常见 格式 

顾名思义 ,连接 字符 串 是 说 明 数 据 库 连 接 信息 的 一 个 字符 序列 ,常见 格式 如 下 。 
(1) 采用 Windows 信任 方式 访问 数据 库 


Data Source = < 数据 库 服务 器 名 >; Initial Catalog = < 数据 库 名 >; Integrated Security = True; 
Pooling = False 


(2) 采用 SQL 方式 访问 数据 库 
Data Source = < 数据 库 服 务 器 名 >; Initial Catalog = < 数据 库 名 >; uid = < 用 户 名 >; pwd = < 密码 >; 
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Pooling = False 


例如 ,下 面 的 连接 字符 串 代表 访问 本 地 计算 机 (用 英文 句号 代替 ) 的 sqlexpress SQL 
Server 服务 器 上 的 数据 库 ,数据 库 名 称 为 XSGL, 采 用 Windows 信任 方式 连接 ， 


Data Source = .\sqlexpress; Initial Catalog = XSGL; Integrated Security= True; Pooling = False 


4) 建立 数据 库 连接 的 示例 
(1) 采用 Windows 信任 方式 连接 本 地 计算 机 SQL Server 2005 服务 器 (服务 器 名 称 为 
JXHD) 上 的 数据 库 WebJx。 常 用 的 语句 片段 为 : 


String strCon = "Data Source = .\JXHD; Initial Catalog = WebJx; Integrated Security = True; 

Pooling = False;" 

SqlConnection conn = new SqlConnection(strCon) ; 

conn. Open() 7 

(2) 采用 用 户 名 Test\ 密 码 abc123 连接 本 地 计算 机 SQL Server 2005 服务 器 (服务 器 名 
称 为 JXHD) 上 的 数据 库 WebJx。 常 用 的 语句 片段 为 : 

SqlConnection conn = new SqlConnection(); 

conn. ConnectionString = "Data Source = . \JXHD; Initial Catalog = WebJx; uid = Test; pwd = abc123; 

Pooling = False;" 

conn, Open( ); 

2. SqlCommand 控件 

1) SqlCommand 控件 的 作用 

SqlCommand 控件 的 作用 是 在 SqlConnection 的 基础 上 执行 SQL 语句 ,从 而 对 数据 库 
的 内 容 产 生 影 响 。 

SqlCommand 控件 可 以 执行 的 语句 分 为 两 类 ,一 类 是 查询 语句 ,返回 记录 集结 果 , 使 用 
ExecuteReader() 方 法 执行 ; 另 一 类 是 更 新 语句 ,不 返回 记录 集 , 使 用 ExecuteNonQuery() 
方法 执行 。 

2) SqlCommand 控件 的 两 种 语法 形式 

与 SqlConnection 相似 ,SqlCommand 也 有 两 种 语法 形式 。 其 一 ,是 直接 把 SQL 语句 作为 
SqlCommand 构造 函数 的 参数 ; 其 二 ,是 把 SQL 语句 作为 SqlCommand 的 CommandText 属性 
的 值 使 用 。 二 者 实现 的 功能 相同 ,但 方法 一 更 为 简洁 。 

(1) 方法 一 : SqlCommand 志 命 令 对 象 名 之 =new SqlCommand(SQL 语句 ,连接 名 ); 

(2) 方法 二 : SqlCommand 所 命令 对 象 名 之 =new SqlCommand(); 

< 命令 对 象 名 >. CommandText = SQL 语句 ; 

< 命令 对 象 名 >. Connection = 连接 名 ; 

注意 : 定义 SqlCommand 时 并 没有 真正 地 执行 SQL 语句 ,只 有 发 送 执行 命令 时 才 真 正 
地 执行 SQL 语句 。 

3) 执行 SqlCommand 中 的 SQL 语句 

(1) 对 于 查询 语句 ,需要 返回 结果 值 ,因此 使 用 以 下 命令 : 


SqlDataReader < 记录 集 名 称 > = < 命令 对 象 名 >. ExecuteReader( ); 
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(2) 对 于 更 新 语句 ,不 需要 返回 结果 值 , 因 此 使 用 以 下 命令 : 
< 命令 对 象 名 >. ExecuteNonQuery(); 


3. 输出 查询 结果 

1) SqlDataReader 控件 的 作用 

SqlDataReader 对 象 保存 查询 结果 ,实质 上 是 一 个 记录 集 对 象 。 对 于 记录 和 集 对 象 来 讲 ， 
其 方法 “Read() "表示 读 取 一 条 记录 ,而 方法 “getString( 列 序号 )”; 则 表示 从 当前 记录 中 获 
得 指定 列 的 数据 。 

例如 ,语句 “rs. getString(1);” 表 示 获 得 当前 记录 中 第 2 个 字段 中 的 数据 ,因为 列 序号 
从 0 开始 。 

2) 输出 SqlDataReader 对 象 中 的 数据 

作为 一 个 多 记录 的 记录 集 ,C# 没 有 提供 直接 输出 其 全 部 数据 的 语句 ,通常 需要 编写 一 
段 程序 ,以 循环 语句 输出 其 全 部 记录 。 其 流程 图 如 图 8-2 所 示 。 


建立 记录 集 对 象 RS 


RS 游标 不 在 表 中 


输出 “ 找 不 到 !” 


输出 游标 指示 的 记录 的 字段 值 


1 
RS 游标 后 移 一 条 记录 


L_ | 
8-2 以 SqlCommand 查询 记录 并 输出 信息 的 程序 流程 图 


假设 记录 集 对 象 名 称 为 rs, 那 么 最 简单 的 语句 为 ; 


while(rs. Read( )) 

{ Response. Write(rs. getString(0)); 
Response. Write(rs. getString(1)); 
Response. Write(rs. getString(2)); 

} 

随 着 ASP.NET 的 发 展 ,VS2005 及 其 以 后 的 版 本 提供 了 GridView 控件 ,为 批量 显示 
数据 表 的 内 容 提 供 了 便利 。SqlDataReader 对 象 可 以 直接 赋予 GridView 数据 源 ,利用 
GridView 批量 输出 。 

4. 书写 SQL 语句 

在 动态 网 站 开发 中 ,与 数据 库 交 互 是 无 法 回避 书写 SQL 语句 的 ,特别 是 书写 带 有 参数 
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的 交互 语句 ,一 直 令 很 多 初学 者 困惑 。 由 于 SQL 语句 是 以 字符 串 的 形式 嵌入 到 高 级 语言 
的 ,常常 导致 在 SQL 字符 串 中 出 现 层 层 凡 套 的 双 引 号 . 单 引 号 和 逗号 ,往往 令 初学 者 困惑 。 
下 面 笔 者 将 通过 具体 的 案例 ,对 SQL 语句 的 撰写 进行 简单 总 结 。 

例如 ,在 窗 体 中 有 一 个 TextBox 控件 ,控件 的 名 称 为 T1; 已 经 定义 的 学 生 表 ( 结 构 为 学 
号 姓名、 性 别 、 年 龄 .奖励 )。 问 题 : 四 如 果 要 查询 姓名 等 于 控件 T1 之 值 的 学 生 的 全 部 信 
息 , 这 个 SQL 语句 应 该 如 何 写 ?@@ 如 果 要 为 这 个 学 生 表 编 写 一 个 插入 程序 ,分 别 由 文本 框 
TA、TB、TC、TD,、TE 提供 数据 ,那么 插入 语句 又 该 如 何 撰写 呢 ? 

1) 抽取 替代 法 

所 谓 抽取 替代 法 ,就 是 先 对 未 知 变量 假设 一 个 初 值 ,撰写 出 一 个 完整 的 SQL 语句 ,然后 
用 "十 变量 名 十 "取代 对 应 位 置 的 常量 (注意 : 替代 时 不 包含 最 外 层 的 中 文 双 引号 ) 。 

对 于 问题 O ,假设 查找 已 知 姓名 (例如 , 王 晓 丽 ) 同 学 的 信息 ,可 以 写 出 SQL 语句 ， 


String sqls = "select * from 学 生 表 where 姓名 = ' 王 晓 丽 "; 


注意 在 人 名 “ 王 晓 丽 ” 的 前 后 各 有 一 个 单 引 号 ,因为 在 SQL 语言 中 要 把 字符 串 常量 用 单 
引号 括 起 来 。 现 在 用 “" 十 变量 名 十 ”取代 SQL 语句 中 的 “ 王 晓 丽 ”三 个 字 , 即 用 
“" 十 T1. Text 十 "” 取 代 “ 王 晓 丽 ”三 个 字 。 注 意 不 要 改变 王 晓 丽 前 后 的 单 引号 ,于 是 得 到 如 
下 所 示 的 结果 : 


String sqls = "select * from 学 生 表 where 姓名 = '" + Tl. Text + "'"; 


同样 ,对 于 问题 @ ,我 们 假设 插入 信息 为 “S109 . 李 晓 华 , 女 ,19,200”, 那 么 可 以 书写 出 
SQL 语句 : 


String sqls = "Insert into 学 生 表 ( 学 号 ,姓名 , 性别, 年 龄 ,奖励 ) 
Values('S109', ' 李 晓 华 ', ' 女 ',19,200)"; 


按照 前 述 思路 ,对 常量 进行 抽取 替代 ,得 到 融合 了 变量 的 SQL 语句 : 
String sqls = "Insert into 学 生 表 ( 学 号 ,姓名 ,性 别 ,年 龄 , 奖励) Values('" + TR. Text + "','" + TB. 


Tantt "+ Tatt" "+ Ttt+", "+ Mat")"; 

对 于 以 此 法 获得 的 SQL 语句 ,可 以 直接 交 给 SqlCommand 执行 。 如 果 直 接 使 用 
Response. Write 语句 输出 此 字符 串 sqls, 会 发 现 这 是 一 个 包含 了 各 个 输入 值 的 完整 的 SQL 
语句 。 

2) SqlCommand 参数 法 

SqlCommand 支持 在 用 户 提交 的 SQL 语句 中 包含 以 "@” 标 记 的 参数 ,但 要 求 用 户 必 须 
在 正式 执行 命令 前 为 所 有 的 参数 赋值 。 

对 于 前 述 问 题 @O ,可 以 使 用 下 面 的 语句 序列 ， 

String sqls = "select * fronm 学 生 表 where 姓名 = @XM"; 

SqlCommand sqlcmd = new SqlCommand( sqls,< 连 接 名 >) ; 

但 在 真正 执行 sqlcmd. ExecuteReader( ) 前 ,必须 先 为 参数 赋值 : 

sqlcmd. Parameters. AddWithValue("@XM", T1. Text); 


同 理 ,对 于 问题 @@, 可 以 写 出 带 有 多 个 参数 的 SQL 语句 : 
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String sqls = "Insert into 学 生 表 (学 号 ,姓名 ,性 别 ,年 龄 ,奖励 ) 
Values( @xh, @xn, @xb, @xsAge, @xsJ1)"; 
SqlCommand sqlcmd = new SqlCommand( sqls, < 连接 名 >); 


然后 ,在 真正 执行 sqlcemd. ExecuteNonQuery() 前 ,必须 先 为 参数 赋值 : 


sqlcmd. Parameters. AddWithValue( "(@xh", TA. Text); 

sqlcmd. Parameters. AddWithValue( "(@xm", TB. Text); 

sqlcmd. Parameters. AddWithValue( "(@xb", TC. Text); 

sqlcmd. Parameters. AddWithValue( "(@xsAge", Convert. ToInt32('TD. Text) ); 

sqlcmd. Parameters. AddWithValue("(@xsJl1", Convert. ToInt32(TE. Text)); 

注意 ; 参数 赋值 时 ,必须 要 注意 类 型 匹配 ,不 要 赋予 与 字段 类 型 不 匹配 的 错误 参数 。 

3) 借用 String. Format() 方 法 

归根 结 底 ,SQL 语句 是 一 个 高 级 语言 交付 数据 库 管理 系统 运行 的 字符 串 , 其 预 处 理 必 
然 可 以 和 普通 字符 串 一 样 使 用 各 种 参数 和 函数 。 为 此 ,笔者 认为 借助 String. Format() 方 法 
对 参数 进行 设置 ,可 以 极为 便利 地 处 理 SQL 字符 串 。 

对 于 问题 @ ,可 以 先 预 设 查询 “ 王 晓 丽 ”, 写 出 如 下 所 示 的 SQL 语句 : 


String sqls = "select * from 学 生 表 where 姓名 = ' 王 晓 丽 ""; 

借助 参数 法 ,更 改 为 如 下 语句 : 

String sqls = String. Format("select x* from 学 生 表 where 姓名 = '{0}",T1. Text); 

在 此 语句 中 ,{0} 代 表 此 格式 化 语句 中 的 第 一 个 参数 ,String. Format 会 自动 用 T1. Text 
的 内 容 取代 它 。 通 过 这 种 方式 ,可 以 获得 一 个 完整 的 ,无 参数 的 SQL 语句 。 

同 理 , 对 于 问题 @ ,可 以 先 给 予 预 设 值 , 写 出 如 下 形式 的 语句 : 


String sqls = "Insert into 学 生 表 ( 学 号 ,姓名 ,性 别 , 年 龄 ,奖励 ) 
Values('S109', ' 李 晓 华 ', ' 女 ',19,200)"; 


然后 借用 格式 化 语句 方法 ,用 变量 取代 其 中 的 常量 。SQL 语句 可 以 如 下 书写 


String sqls = String. Format("Insert into 学 生 表 ( 学 号 ,姓名 ,性 别 ,年 龄 ,奖励 ) 
Values( '{0}', "{1}", '{2}", {3}", {4}')", TA. Text, TB. Text, TC. Text, TD. Text, TE. Text); 


以 此 方法 撰写 带 有 参数 的 SQL 语句 ,具有 效率 高 、. 易 懂 的 特点 。 
8.1.3 ”SqlCommand 应 用 实例 


1. 以 SqlCommand 实现 数据 查询 

已 知 本 地 计算 机 SQL Server 2005 服务 器 (服务 器 名 称 为 sqlexpress) 上 的 数据 库 为 
xsgl。 其 中 包括 学 生 表 , 其 结构 为 {学 号 ,姓名 ,性 别 ,生日 ,单位 ,电话 }。 请 以 Windows 信 
任 方式 连接 数据 库 , 并 根据 学 生 姓名 查询 学 生 信息 。 

(1) 设计 思路 

新 建 一 个 Web 窗 体 ,并 在 其 中 加 入 一 个 文本 框 和 一 个 按钮 。 当 用 户 在 文本 框 中 输入 数 
据 并 单 击 按钮 后 ,程序 应 该 能 够 连接 数据 库 , 并 利用 SqlCommand 命令 执行 SQL 查询 语句 ， 
最 后 把 查询 结果 SqlDataReader 的 内 容 输出 。 
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(2) 设计 过 程 

首先 ,在 项 目 中 新 增 Web 窗 体 DbCommTest, 并 输入 必要 的 提示 性 文字 ,设置 好 字体 。 

其 次 ,加 入 一 个 TextBox ,一 个 Button 和 一 个 Label。 修 改 TextBox 的 ID 为 T1; 修改 
Button 的 ID 为 btnFind,Text 属性 为 查找”; 修改 Label 的 ID 属性 为 txtRes,Text 属性 为 
空白 。 

后 ,双击 按钮 btnFind, 为 btnFind_Click 事件 编写 代码 。 

注意 : 因 .NET 3.5 推荐 使 用 DataSource 和 LINGQ 技术 ,已 经 默认 不 支持 SqlCommand 
和 SqlConnection ,所 以 需要 在 C 划 代码 的 开始 部 分 添加 引用 命名 空间 的 语句 “using 
System. Data. SqlClient; ”。 


(3) 最 终 代 码 
运行 效果 如 图 8-3 所 示 ,最 终 代码 如 图 8-4 所 示 。 
学 生 信息 查询 
请 输入 学 生 姓名 ， 到 大 源 2 [| 


S002 麻 大 源 2 | 男 |1990/1/12 00000 抽 育 系 教育 史 |687991234 


图 8-3 以 SqlCommand 查询 记录 的 最 终 效果 图 


24 四 protected void btnFind Click(object sender，Eventargs e) 
{ 


String strCon = "Data Source=.\\sqlexpress;Initial Catalog=XSGL; "; 
strCont=" Integrated Security=True;Pooling=False" ; // 数 据 库 连 接 字符 证 

SqlComection com = new SqlConrnection(strCon) ; // 建 立 数 据 库 连接 对 象 

corm. Open() ; V/ 打 开 数 据 库 连 接 


String sqls = String, Format (@"select xh, xm xb, csdat e, dwei, zhye, phone from 
学 生来 where xm=' {0}'"，T1. Text, Trin()) ; “AASQL 滞 名， 因 参数 和 换行 ， 加 入 了 @ 标 记 
SqlCommand sqlcnd = new SqlCommand(sqls，commn) ; ”// 在 连接 上 创建 5qlCommand 对 象 
SqlDataReader ， dr = = sqlcnd. ExecuteReader(); /1 执行 查询 
String str = 
while (dr.Read()) { 
str=str+dr. GetString (0)+" |" ; // 查 询 结果 存 傅 到 str 中 
str=str+dr.GetString(1) + ”|": 
str=str+dr.GetString(2) + ”|": 
str=strtdr. GetDateTine (3). ToString 0 让 
str=str+tdr. GetString(4) + " 
str=str+dr.GetString(5) + " |':; 
i str=str+tdr, GetString (6) + "<br>"; 
sqlcnd = null; 
corm. Close(); 
txtRes. Text = str; // 显 示 查 词 结果 


8-4 以 SqlCommand 查询 记录 的 C# 代 码 


2. 以 SqlCommand 实现 数据 插入 

(1) 案例 要 求 

已 知 本 地 计算 机 SQL Server 2005 服务 器 (服务 器 名 称 为 sqlexpress) 上 的 数据 库 为 
xsgl。 其 中 包括 学 生 表 , 该 表 结构 为 { 学 号 ,姓名 ,性 别 ,生日 ,单位 ,电话 }。 以 Windows 信 
任 方式 连接 数据 库 ,能 够 向 学 生 表 中 插入 学 生 信息 ,程序 的 运行 效果 如 图 8-5 所 示 。 
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学 生 信 息 输入 
学 号 ，S863 姓名 ， 王 如 平 
性 别 ， 支 生日 ，1981-12 让 
单位 ， 生 物 系 电话 。98213 
保存 
过 | zm | 二 csdate dwei | zhye phone | ie 


Al100 张 萍 军 女 1997/1/1000:00 生物 系 ”生物 史 。 12345678 200 
S001 张 薄 志 女 1989/12/1 00000 物理 系 物理 学 687091234 900 
S002 李 大 源 2 男 1990/1/12 00000 教育 系 教育 史 。 687991234 0 
S003 刘 明 女 1990/4/1200000 物理 系 ”物理 学 。 698721212 100 
S004 看 丽 丽 女 _199UUL 00000_ 教育 系 学 前 教育 698712345 400 ~ 


8-5 以 SqlCommand 插入 记录 的 程序 运行 效果 图 


(2) 设计 思路 

新 建 一 个 Web 窗 体 ,并 在 其 中 加 入 6 个 文本 框 和 1 个 按钮 。 当 用 户 在 文本 框 中 输入 数 
据 并 单 击 按钮 后 ,程序 应 该 能 够 连接 数据 库 , 并 利用 SqlCommand 命令 执行 SQL 插入 语句 ， 
把 记录 插入 到 数据 表 中 ,并 输出 数据 表 的 内 容 。 

(3) 设计 过 程 

首先 ,在 项 目 中 新 增 Web 窗 体 DbCommJnsert ,并 输入 必要 的 提示 性 文字 。 

其 次 ,加 入 6 个 TextBox 1 个 Button 和 1 个 Label。 依 次 修改 TextBox 的 ID 为 
txtXh txtXm txtXb ,txtSr\txtDw txtDh; 修改 Button 的 ID 为 btnSave,Text 属性 为 “ 保 
存 ”; 修改 Label 的 ID 属性 为 lblRes,Text 属性 为 空白 。 

最 后 ,双击 按钮 btnSave, 进 入 到 C# 编 码 状态 。 首 先 在 C# 代码 的 开始 部 分 添加 引用 
命名 空间 的 语 名 “using System. Data. SqlClient; ”, 然 后 为 btnSave_Click 事件 编写 代码 。 

(4) 最 终 代 码 

运行 效果 如 图 8-5 所 示 ,程序 的 最 终 代码 如 图 8-6 所 示 。 


24 四 protected void btnSave_Click(object sender，Eventargs e) 

25 { 

26 String strCon = "Data Source=.\\sqlexpress:Initial Catalog=XSGL; ": 

27 strCon += "Integrated Security=True;Pooling=False" ; // 数 据 库 连接 字符 串 

28: SqlCormection com = new SqlCormnection(strCon);  // 建 立 数据 库 舌 接 对 象 

29 corm. Open() ; /打开 数据 库 舌 接 

301 

31 String sqls = String.Format (@"insert into 学 生 表 (xh, xn, xb, csdate, dwei, phone) 
2 values( {0}',' {1}'," {2}"," {3}", " {4}',' {5}')", txtXh. Text, txtXm. Text, txtXb. Text, txtSr. Text, 
33 txtDw, Text，txtDh. Text) ; // 插 入 数据 的 5QL 语 句 ， 因 过 长 而 换行 ， 以 @ 开 头 

34 

35 SqlCommand scmd = new SqlCommand(sqls，conm) ; ”// 在 连接 上 创建 Sq1Command 对 象 
36 scmd. ExecuteNonQuery() ; 

37 

38 String sql = String,Fornat ("select * from 学 生 表 order by xh"). 

39 /15QL 语 句 ， 输 出 所 有 记录 

40 SqlCommand sqlcnd = new SqlCommand(sql，conmn) ; ”// 在 连接 上 创建 qlCommand 对 象 

d1 SqlDataReader dr = sqlcmd. ExecuteReader(); z/ 执 行 查 调 

42 gvisb. DataSource = dr:; ff 显示 查询 结果 

43 gvisb. DataBind() ; 

dd sqlcmd = rull; 

45 corm Close(); 

46ir } 


图 8-6 以 SqlCommand 插入 记录 的 C# 代 码 
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@.2 基于 DataAdapter 访问 数据 库 
8.2.1 DataAdapter 访问 数据 库 的 原理 


1. DataAdapter 简介 

(1) DataAdapter 的 起 源 

DataAdapter( 数 据 库 适 配器 ) 控 件 是 Web 访问 数据 库 中 的 重要 成 员 。 在 Microsoft 提 
供 的 数据 库 访问 技术 中 ,DataAdapter 控件 是 对 Command 对 象 的 重要 扩展 ,首次 把 查询 操 
作 和 更 新 操作 统一 在 同一 对 象 中 ,使 开发 者 能 够 真正 地 把 高 级 语言 范畴 以 外 的 数据 库 看 做 
一 个 完整 的 对 象 ,是 数据 库 访问 技术 的 重要 进步 。 

如 果 把 基于 Command 对 象 的 数据 库 访 问 看 做 Web 数据 库 技术 的 发 端 ,那么 
DataAdapter 技术 可 以 称 为 第 2 代 ,DataSource 则 是 第 3 代 ,LINQ 技术 就 是 第 4 代 , 代 表 着 
Web 数据 库 访 问 技术 发 展 方向 。 

(2) DataAdapter 的 地 位 

DataAdapter 控件 在 建立 Connection 的 基础 上 ,负责 SQL 语句 的 执行 。 与 后 来 的 
DataSource 控件 相似 , 它 也 提供 了 SelectCommand、UpdateCommand 、 InsertCommand、 
DeleteCommand 等 属性 ,允许 开发 者 利用 它 实施 数据 查询 .数据 修改 .数据 插入 和 数据 删除 
操作 。 

与 DataAdapter 同时 代 的 重要 控件 是 DataSet 控件 。 人 们 可 以 把 DataSet 看 做 一 个 针 
对 实际 数据 库 的 内 存 映 像 , 是 一 个 内 存 数据 库 。 与 客观 数据 库 相 似 , 在 这 个 内 存 数 据 库 中 也 
可 以 存放 多 张 数 据 表 , 供 用 户 快速 便捷 地 访问 。 因 此 ,DataSet 为 人 们 提供 了 一 种 机 制 ,使 
得 人 们 可 以 在 无 连接 的 情况 下 访问 数据 表 的 内 容 。 存 放 于 DataSet 中 的 记录 可 以 被 高 层 控 
件 调 用 ,支持 读 取 和 更 新 操作 , 它 和 DataReader 控件 (DataReader 控件 提供 只 读 服务 ) 一 起 
构成 了 内 存 数据 库 的 两 种 形态 。 

DataAdapter 控件 起 到 一 种 承上启下 的 功能 , 它 建立 在 Connection 的 基础 上 ,通过 执行 
SQL 语句 为 DataSet 填充 数据 ,或 者 把 DataSet 中 的 更 新 回 写 到 磁盘 数据 库 , 实 现 数据 的 持 
久 化 。 

(3) DataAdapter 的 类 

与 前 述 的 Command 对 象 相似 ,为 适应 不 同 的 数据 库 访问 要 求 ,Microsoft 也 提出 了 适 
应 不 同 数据 库 类 型 的 DataAdapter 类 ,如 访问 Access 数据 的 OleDbDataAdapter 类 ,访问 
SQL Server 数据 库 的 SqlDataAdapter 类 等 。 不 过 二 者 仅 是 语法 的 差异 ,使 用 方法 基本 相 
同 ,本 节 主 要 以 访问 SQL Server 数据 库 为 例 , 讲 授 SqlDataAdapter 的 使 用 。 

2. DataAdapter 访问 数据 库 的 结构 体系 

(1) SqlDataAdapter 技术 的 发 展 与 体系 

为 便利 地 访问 数据 库 , 从 .NET 1. 1 版 本 开始 ,Microsoft 就 不 断 地 为 ASP.NET 开发 工 
具 增 添 新 的 数据 库 访问 控件 。 随 着 版 本 的 更 替 , 控 件数 量 日 益 增 多 ,部 分 控件 已 经 逐步 退出 
系统 开发 的 主 战 场 。 目 前 ,比较 典型 的 控件 有 Connection、DataAdapter、 DataSet DataView、 
Datalist. DataGrid GridView、Repeater\DataReader .DataTable .FormView DetailsView 等 。 
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在 众多 数据 库 访问 控件 中 ,最 基础 的 控件 是 数据 库 连接 控件 (Connection) ,第 二 层 的 控 
件 是 数据 库 适 配器 控件 (DataAdapter) 和 数据 库 命令 控件 (Command) ,第 三 层 的 控件 是 数 
据 集 控 件 (DataSet)、 读 取 数 据 集 控件 (DataReader), 第 四 层 的 控件 是 数据 表 控 件 
(DataTable) 和 数据 表 视 图 控件 (DataView) 。 最 高 层 是 表示 层 控件 ,其 目标 是 在 Web 页 面 
中 呈现 数据 记录 , 即 窗 体 显示 控件 。 这 些 控 件 能 够 直接 放 在 窗 体 中 ,为 记录 的 个 性 化 显示 提 
供 支 持 ,主要 有 DataGrid、DataList、Repeater、GridView、FormView 等 。 各 种 控件 的 层次 关 
系 如 图 8-7 所 示 。 


SqlConnection ConnectionString= 


四 


SqlDataAdapter 


Update(DataSet, 表 名 ) Fill(DataSet, 表 名 ) 


DataSet 


Tables[] 属 性 


DefaultView 


DataView DataTable 


RowFilter= 
Sort= a 2 > Rows[ 行 号 ].Delete( ) 
对 象 名 0 | DataGrid/GridView | | DataList | Repeer | Rows.Add( 行 对 象 ) 
Rows[ 行 号 ][ 列 号 ] 
DataSource 属 性 的 值 由 DataView 或 DataTable 对 象 赋予 Rows.Count 


8-7 以 SqlDataAdapter 访问 数据 库 的 结构 体系 


在 数据 库 对 象 的 层次 关系 图 中 ,前 面 的 3 层 都 是 用 于 数据 库 后 台 操作 的 ,其 中 前 面 2 层 
与 具体 的 数据 库 管 理 系 统 相 关 , 需 要 使 用 对 应 的 子 类 。 例 如 ,访问 SQL Server 使 用 
SqlDataAdapter 和 SqlConnection ,访问 Access 使 用 OleDbDataAdapter 和 OleDbConnection 对 
象 。 后 面 的 2 层 则 与 具体 的 DBMS 没有 关系 ,使 用 统一 的 对 象 名 称 。 

位 于 末端 的 DataGrid、DataList、Repeater、GridView、FormView 和 DetailsView 则 是 
用 于 前 台 显示 的 ,可 直接 被 拖 放 到 Web 窗 体 中 , 仅 与 开发 工具 版 本 相关 ,与 DBMS 无 关 。 
其 中 的 DataGrid 和 GridView 是 使 用 比较 频繁 的 窗 体 控件 。 

(2) 控件 与 ASP.NET 版 本 的 版 本 关系 

图 8-7 描述 了 以 数据 库 适配器 对 象 访 问 数据 库 的 体系 ,这 一 体系 结构 建立 在 .NET 1.1 
的 基础 上 ,是 VS 2003 支持 的 结构 。 随 后 ,Microsoft 逐步 地 对 上 述 体 系 进行 整合 , 尽 可 能 地 
屏蔽 数据 库 操作 的 底层 体系 。 至 .NET 2. 0 以 后 的 版 本 ,把 数据 库 连 接 对 象 (Connection) 、 
数据 库 适配器 对 象 (DataAdapter) ,数据 库 命 令 对 象 (Command) 和 内 存 数据 集 DataSet 对 
象 .DataReader 对 象 整合 为 一 体 ,提出 了 DataSource 控件 的 概念 。 与 此 同时 ,Microsoft 也 
对 表示 层 的 控件 进行 了 整合 和 优化 ,到 VS2008 体系 下 ,表示 层 的 控件 只 保留 了 GridView、 
ListView、DetailsView、DataList 和 Repeater 等 几 个 。 
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因此 ,在 VS2008 开发 工具 中 ,把 DataSource 和 LINQ 技术 作为 默认 的 开发 环境 ,已 经 基本 
按 弃 了 DataAdapter 这 一 技术 。 要 在 VS2008 下 利用 这 一 技术 开发 系统 ,就 必须 在 C# 文 档 的 
开头 引入 相关 的 命名 空间 System. Data. SqlClient( 或 System. Data. OleDb), 即 在 C# 的 引 
用 命名 空间 区 域 增加 语句 : using System. Data. SqlClient( 或 using System. Data. OleDb) 。 


8.2.2 SqlDataAdapter 数据 库 访 问 技术 


1. SqlDataAdapter 实施 数据 库 访问 的 流程 

以 SqlDataAdapter 访问 数据 库 并 实施 更 新 操作 是 .NET 1. 1 支持 的 主要 的 数据 处 理 模 
式 ,其 主要 遵循 以 下 5 个 步骤 。 

1) 创建 数据 库 连 接 

利用 连接 字符 串 创建 数据 库 连 接 , 获 取 可 用 的 SqlConnection 连接 对 象 是 实施 
SqlDataAdapter 数据 访问 的 前 提 。 

例如 ,通过 下 面 的 语句 序列 获得 了 一 个 名 称 为 conn 的 数据 连接 对 象 : 


String strCon = "Data Source =. \ JXHD; Initial Catalog = WebJx; Integrated Security = True; 

Pooling = False;" 

SqlConnection conn = new SqlConnection( strCon); 

conn. Open( ); 

2) 创建 SqlDataAdapter 对 象 

给 予 目标 数据 表 一 个 查询 语句 ,并 让 这 个 查询 语句 配合 前 述 的 SqlConnection 对 象 创 
建 SqlDataAdapter 对 象 。 

首先 撰写 一 个 SQL 的 查询 语句 ,存储 在 字符 串 变 量 sqls 中 。 


String sqls = "select … "7 

然后 创建 SqlDataAdapter 对 象 : 

SqlDataAdapter sqlcd = new SqlDataAdapter( sqls, conn); 

如 果 需 要 利用 此 SqlDataAdapter 对 象 实施 数据 更 新 操作 , 则 要 求 它 对 应 的 数据 表 应 该 
已 经 设置 主键 ,而且 其 查询 语句 满足 行列 子 集 视 图 的 规范 。 那 么 可 以 利用 下 列 语句 为 此 对 
象 完善 其 他 SQL 语句 : 

SqlCommandBuilder cb = new SqlCommandBuilder( sqlcd); 

3) 填充 DataSet, 获 得 DataSet 对 象 

创建 一 个 DataSet 对 象 ,然后 让 SqlDataAdapter 对 象 把 数据 填充 到 这 个 DataSet 中 : 


DataSet ds = new DataSet( ); 

sqlcd. Fill(ds, "数据 表 别 名 "); 

4) 利用 业务 层 控 件 实施 数据 处 理 

当 DataSet 对 象 被 创建 后 ,就 可 以 利用 这 个 对 象 实施 业务 活动 了 。 由 于 DataSet 是 一 个 内 
存 数据 库 , 为 节约 服务 器 资源 ,此 时 可 以 让 服务 器 断 开 数 据 库 连接 ,专心 处 理 用 户 的 业务 。 

常见 的 操作 有 : 
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。 利用 DataSet 对 象 获得 DataTable 对 象 ,利用 DataTable 实现 数据 修改 、 数 据 插入 、 
数据 删除 等 操作 。 
。 利用 DataSet 对 象 获得 DataView 对 象 ,利用 DataView 对 象 实施 记录 过 滤 、 数 据 提 
取 等 操作 。 
当然 ,在 这 个 过 程 中 可 以 借助 GridView、DataList、DataGrid 等 控件 。 
5) 处 理 结果 回 存 到 数据 库 
如 果 曾 经 修改 了 数据 内 容 而 且 需 要 把 更 新 回 写 到 磁盘 上 ,那么 就 需要 调用 
SqlDataAdapter 对 象 的 Update() 方 法 ,实现 对 外 存 数 据 的 更 新 。 
2. SqlDataAdapter 实施 数据 库 访问 示例 
(1) 基于 SqlDataAdapter 的 数据 查询 
基于 前 述 的 学 生 数 据 库 ,查找 学 号 为 文本 框 Tl 之 值 的 学 生 的 姓名 ,姓名 显示 在 Label 
指明 的 位 置 。 
假设 Button 按钮 的 ID 是 btnFind, 显 示 姓 名 的 Label 的 ID 显示 lblXm。 那 么 响应 
btnFind 按钮 的 Click 事件 的 代码 如 图 8-8 所 示 。 


protected void btnFind_Click(object sender, Eventhrgs e) 
{ 


String strCon = "Data Source=. \\sqlexpress:Initial Catalog=XSGL; 
strCon += "Integrated Security=True:Pooline=False" ; 和 
SqlCormection com = new SqlCormnection(strCon) ; // 建 立 数据 库 连 接 
corm. Open() ; 


等 
对 象 


String sqls = "select * from 学 生 表 " 
SqlDatahdapter sqlAdap = new 3 ahdapter (sqls, co 

/本 命令 仅仅 用 于 查 向 ， 和 
DataSet ds = new DataSet () ; 
sqlAdap. Fill (ds, "xsb"); AZ/ 填充 数据 到 ds 中 , 内 存 数据 表 别 名 为 xsb 
DataView dv = ds.Tables["xsb"].DefaultView: // 获 得 DataView 对 象 


dv, RowFilter = "xh='" + Tl,Text,Trin() + "'"; // 书 瑟 数 据 过 滤 条 件 

证 (dv.Count > 0) 7 从 是 时 寺 了 了 记录 
lblxn. Text = dv[0][1]. ostrine Os 71/ 输出 首 个 记录 第 2 列 的 时 

else 1blXm. Text = "记录 不 存在 

sqlAdap = null; 

conm. Close(); 


图 8-8 以 SqlDataAdapter 实现 数据 查询 的 程序 代码 


提示 : 不 要 忘记 引用 命名 空间 “using System. Data. SqlClient;”。 

(2) 基于 SqlDataAdapter 的 数据 插入 

基于 前 述 的 学 生 数 据 库 , 在 如 图 8-9 所 示 的 输入 界面 已 经 设计 成 功 的 情况 下 ,为 【保存 】 
按钮 编写 保存 程序 。 


学 生 卡 片 信息 输入 四 
学 号 ，bdh 姓名 ，bdym 
性 别 ，bob 生日 ，basr 
电话 ，taDh 单位 ，bdtDw 
专业 :bazhy 奖学金 ，bdj 
全 于 


8-9 以 SqlDataAdapter 实现 记录 插入 的 最 终 效 果 图 
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假设 Button 按钮 的 ID 是 btnSave, 其 他 文本 框 控件 的 ID 如 图 8-9 所 示 。 那 么 响应 
btnSave 按钮 的 Click 事件 的 代码 如 图 8-10 所 示 。 


48 和 protected void btnSave_Click (object sender, Eventhrgs e) 
{ 


49 

50 String strCon = "Data Source=. \\sqlexpress; Initial Catalog=XSGL; "; 

51 strCon += "Integrated Security=True;Pooling=False" ; // 数 据 库 连 接 字符 趾 
52 SqlCormection corm = new SqlCormection(strCon) ;  ”// 建 立 数据 库 连 接 对 旬 
53 corm. Open() ; 

54d 

55 String sqls = "select * from 学 生 表 " 

56 SqlDatahdapter sqlAdap = new SqlDatahdapter (sqls, corm):; 

57 SqlCommandBuilder cb = new SqlCommandEuilder(sqlAdap) : 

58 // 因 本 程序 需要 更 新 数据 ， 由 对 象 cb 负责 创建 更 新 用 的 SQL 语句 

59 DataSet ds = new DataSet (); 

60 sql&Adap.Fill(ds，"xsb") : /1 填充 数据 到 ds 中 , 内 存 数据 表 别 名 为 xsb 
61 DataTable dt = ds.Tables["xsb"]; // 获 得 DataTable 对 象 

62 

63 DataRow row = dt, NewRow(); AZ/ 依据 此 的 结构 新 建 一 个 空 行 

64 row[0] = txtXh. Text. Trim(); ”// 把 数据 存储 到 对 应 的 字段 中 

65 row[1] = txtXm. Text, Trim(); 

66 row[2] = txtXb, Text, Trin(); 

67 row[3] = Convert. ToDateTime (txtSr. Text. Trim()) ;// 类 型 转换 

68 row[4] = txtDw. Text. Trin'(). 

69 row[5] = txtZhy.Text.Trimf) ; 

70 row[6] = txtDh. Text, Trin(); 

71 row[7] = Convert. ToInt32 (txtJxj. Text. Trin()); // 数 据 类 型 转换 

人 dt. Rows. Add (row) ; // 把 行 添加 到 数据 表 中 

73 sqlAdap. Update (ds, "xsb"). // 更 新 后 台数 据 库 

74 sqlAdap = null; 

75 comm Close() : 

76 txtXh. Text= txtXm. Text=txtXb. Text=txtSr. Text="" ;// 清 空 数据 

77 txtDw, Text= txtZhy. Text=txtDh。Text=txtJxj, Text=""; 

7T8 } 


图 8-10 以 SqlDataAdapter 实现 记录 插入 的 C# 源 程序 代码 


至 于 删除 与 更 新 程序 ,其 解决 思路 与 前 述 两 种 技术 的 思路 一 致 ,此 处 不 再 袭 述 。 


@.3 数据 库 访问 的 主要 控件 


以 传统 的 DataAdapter 体系 访问 数据 库 , 是 一 种 四 层 结构 ,而 新 型 的 DataSource 和 
LINQ 体系, 则 只 有 两 层 , 极 大 地 简化 了 数据 库 访问 的 流程 。 然 而 ,在 具体 的 开发 中 ,笔者 发 
现 : 尽管 新 型 的 数据 库 访 问 体 系 只 有 两 层 ,但 在 开发 过 程 中 仍然 不 时 地 涉及 以 前 技术 的 相 
关 概 念 。 例 如 ,对 于 DataSource 数据 源 的 类 型 ,就 有 DataSet 或 DataReader 两 种 方式 供 开 
发 者 选择 。 至 于 在 数据 处 理 过 程 中 ,更 是 多 次 涉及 DataTable、DataView 等 概念 。 如 果 不 
清楚 这 些 概念 ,对 于 理解 程序 的 工作 原理 、 阅 读 成 功 的 技术 案例 和 开发 高 效 的 程序 都 是 非常 
不 利 的 。 为 此 ,下 面 将 对 相关 概念 及 其 相互 关系 进行 简要 的 剖析 。 


8.3.1 数据 业务 层 控件 剖析 


1. DataReader 

DataReader 控件 由 Command 对 象 运行 查询 语句 获得 ,具有 占用 资源 小 ,效率 高 .操作 
方式 单一 的 特点 。 在 DataReader 对 象 中 只 能 自前 向 后 地 顺序 读 取 记录 。DataReader 对 象 
不 便于 处 理 规模 巨大 、 查 询 、 更 新 混杂 的 数据 库 访问 。 
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1) 获得 DataReader 对 象 


SqlCommand sqlcd = new SqlCommand( sqlu 查询 语句 ,连接 对 象 名 ); 
DataReader dr = sqlcd. ExecuteReader( ); 


2) 应 用 DataReader 对 象 
假定 DataReader 对 象 dr 已 经 存在 ,那么 对 象 dr 的 用 法 主要 有 以 下 形式 : 


dr.Read() // 执 行 记录 读 取 ,返回 值 如 果 为 false, 则 游标 位 于 表 尾 
dr.getString( 列 序号 ) // 获 得 指定 列 号 的 字符 型 字段 之 值 

上 .getDateTime( 列 序号 ) // 获 得 指定 列 号 的 日 期 时 间 型 字段 之 值 

3) 常见 用 法 


if(!dr. Read( )) Response. Write( "记录 不 存在 !"); 
else while(dr. Read()){ 
Response. Write(dr. getString(0)); 


| 


2. DataAdapter 

DataAdapter 对 象 相当 于 针对 一 个 数据 表 的 SQL 命令 的 集合 , 它 包含 了 针对 一 个 数据 
表 的 Select、Update、Insert、Update 命令 语句 ,而 且 提供 了 一 种 机 制 ,能 够 把 Select 语句 的 
执行 结果 填充 到 DataSet 对 象 中 ,而且 可 以 把 DataSet 的 更 新 回 写 到 磁盘 数据 库 中 。 

需要 特别 说 明 的 是 ,要 使 DataAdapter 对 象 支持 更 新 ,该 对 象 必须 包含 正确 的 更 新 语 
句 ,而 且 后 台 的 磁盘 数据 库 已 经 正确 地 设置 了 主键 ,具有 从 外 部 更 新 数据 的 权限 。 

1) 获取 DataAdapter 对 象 

假设 数据 库 连 接 对 象 已 经 存在 ,名 称 为 conn; SQL 查询 语句 也 已 经 撰写 完毕 , 则 可 以 
通过 以 下 命令 获得 DataAdapter 对 象 ; 


SqlDatahdapter sqladp = new SqlDatahdapter(sql 查询 语句 ,conn) ; 
注意 ; 如 果 Select 语句 的 查询 结果 中 包括 数据 表 的 主键 、 而 且 全 体 数据 列 来 源 于 一 张 


数据 表 。 那 么 此 DataAdapter 应 该 具备 数据 更 新 的 功能 。 为 此 ,可 以 使 用 下 列 命令 自动 地 
为 DataAdapter 对 象 生成 全 部 SQL 语句 : 


SqlCommandBuilder cb = new SqlCommandBuilder(Datahdapter 对 象 名 ) ; 
当然 ,熟练 使 用 SQL 语句 的 开发 者 也 可 以 手工 为 DataAdapter 配置 插入 、 修 改 , 更 新 所 
需 的 SQL 语句 。 例 如 : 


SqlCommand sqlcmd = new SqlCommand( "update 学 生 表 set 姓名 = ' 马 平 ', 年龄 = 19 where 学 号 = 

'01011234"™"); 

sqlAdap. UpdateCommand = sqlcmd;. 

2) DataAdapter 对 象 的 常见 应 用 

DataAdapter 的 主要 应 用 就 是 实现 DataSet 与 后 台数 据 库 的 填充 与 相互 更 新 。 假 设 
DataAdapter 对 象 sqladp 已 经 存在 ,填充 数据 到 DataSet 的 命令 是 : 


DataSet ds = new DataSet( ); 
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sqladp. Fill(ds, "数据 表 别 名 "); 。“”// 数 据 表 别名 与 磁盘 数据 表 名 称 可 以 不 同 ; 
把 DataSet 中 的 数据 更 新 到 后 台数 据 库 的 命令 是 : 


sqladp. Update(ds, "数据 表 别 名 "); 
// 此 处 的 数据 表 别 名 应 该 与 填充 命令 中 的 别名 一 致 ; 

3. DataSet 

DataSet 是 磁盘 数据 库 在 内 存 中 的 一 个 映像 ,可 称 为 内 存 数据 库 , 它 可 以 包括 多 张 数 据 表 ， 
支持 数据 更 新 。DataSet 中 的 数据 表 由 DataAdapter 负责 填充 ,建立 DataSet 与 磁盘 数据 库 的 对 
应 关系 。 如 果 对 应 DataAdapter 包含 有 效 的 数据 更 新 语句 , 则 允许 用 户 直 接 更 新 DataSet 中 的 
数据 ,然后 再 利用 DataAdapter 对 象 把 用 户 对 DataSet 的 修改 持久 化 到 磁盘 数据 库 中 。 

1) 获取 DataSet 对 象 

假设 已 经 存在 一 个 SqlDataAdapter 对 象 sqladp, 而 且 已 经 正确 地 配置 了 Select、 
Update、Insert、Update 命令 语句 , 则 可 以 利用 以 下 命令 填充 DataSet 对 象 : 

DataSet ds = new DataSet( ); 

sqladp. Fill(ds, "内 存 数据 表 别 名 "); 

2) DataSet 对 象 的 常见 应 用 

假设 数据 集 ds 已 经 创建 , 则 Data Set 常见 应 用 如 下 : 

DataTable dt = ds. Tables[ "数据 表 别 名 "]; 

DataTable dt = ds. Tables[ 数 据 表 序 号 ]; 

DataView dv = ds. Tables[ 数 据 表 序号 ]. DefaultView; 

4. DataTable 

DataTable 表示 内 存 中 数据 的 一 个 表 , 它 完全 是 在 内 存 中 的 一 个 独立 存在 ,包含 了 对 应 
磁盘 数据 库 中 某 一 数据 表 的 全 部 信息 。DataTable 对 象 是 通过 连接 从 数据 库 中 读 取 出 来 的 
记录 在 内 存 中 形成 的 一 个 表 , 一 旦 将 内 容 读 到 DataTable 中 ,此 DataTable 就 可 以 与 数据 源 
断 开 而 独立 存在 。 另 外 ,DataTable 也 可 以 完全 由 程序 通过 代码 来 创建 。 

1) 创建 DataTable 

假设 ds 是 一 个 已 经 填充 了 数据 的 DataSet, 那 么 可 以 利用 下 面 的 命令 获得 DataTable 
对 象 : 


DataTable dt = ds. Tables[ "数据 表 别 名 "]; 
或 者 
DataTable dt = ds. Tables[ 序 号 ]; 


DataTable 对 象 还 可 以 从 当前 的 DataSource 对 象 中 获得 ,如 果 存 在 DataSource 对 象 
dsource, 那 么 让 DataSource 对 象 执行 无 参数 的 Select 语句 ,就 能 获得 一 个 DataTable 对 象 ， 
代码 如 下 : 


DataTable dt = (DataTable)dsource. Select(DataSourceSelecthrguments. Empty) 7 


2) DataTable 对 象 的 应 用 
假设 DataTable 对 象 名 称 为 dt ,那么 可 以 使 用 以 下 常见 的 方法 : 
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dt.Rows[ 行 号 ].Delete(); // 删 除 指定 行 号 的 行 

dt.Rows. hdd( 行 对 象 名 ) ; // 把 指定 行 添加 到 数据 表 中 

String xx = 此 .Row[ 行 号 ][ 列 号 ]. ToString(); ”// 把 指定 行 指 定 列 的 数据 赋予 变量 zx 
int num = dt. Rows. Count; // 获 得 数据 表 的 记录 数 ,赋予 变量 num 
5. DataRow 


DataRow 通常 表示 DataTable 中 的 一 行 ,可 以 作为 一 个 整体 被 添加 到 DataTable 中 ,也 
可 以 把 DataTable 对 象 中 的 一 行 提取 出 来 ,构成 DataRow 对 象 。 

在 下 面 的 例子 中 ,假设 数据 表 DataTable 的 对 象 dt 已 经 存在 。 

1) 获得 DataRow 对 象 


DataRow drow = dt. Rows[ 行 号 ]; // 获 得 指定 的 行 ,构成 一 个 DataRow 对 象 ; 
DataRow drow = dt. NewRow( ) ; // 按 照 DataTable 的 结构 创建 新 的 空白 行 ; 


2) DataRow 对 象 的 应 用 


dt.Rows. hdd( 行 对 象 名 ) ; // 把 行 对 象 添加 到 数据 表 dt 中 ; 
String xx = drow[ 列 号 ].ToString(); // 获 取 drow 对 象 中 指定 列 的 数据 ; 
6. DataView 


DataView 是 基于 数据 库 基本 表 的 一 个 视图 , 它 可 以 用 于 排序 .筛选 .搜索 等 操作 ,可 以 
看 做 是 针对 DataTable 的 可 绑 定 数据 的 自 定 义 视 图 。DataView 只 能 对 某 一 个 DataTable 
建立 视图 。 在 下 面 的 例子 中 ,假设 数据 表 DataTable 的 对 象 dt 已 经 存在 。 

1) 获得 DataView 对 象 

DataView dv = dt. DefaultView; // 获 得 数据 表 dt 的 默认 DataView 视图 ; 

DataView dv = ds.Tables[" 表 别名 "].DefaultView; // 从 DataSet 获得 DataView 对 象 ; 

DataView 对 象 还 可 以 从 当前 的 DataSource 对 象 中 获得 ,如 果 存 在 DataSource 对 象 
dsource, 那 么 让 DataSource 对 象 执行 无 参数 的 Select 语句 ,就 能 获得 一 个 DataView 对 象 ， 
代码 如 下 : 


DataView dv = (DataView)dsource. Select(DataSourceSelectArguments. Empty) ; 


2) 应 用 DataView 对 象 
假设 DataView 的 对 象 dv 已 经 存在 , 则 常见 的 操作 有 : 


dv. RowFilter = "条 件 表达 式 " // 对 DataView 执行 查询 ,数据 过 滤 
String xx = dv[ 行 号 ][ 列 号 ].ToString; // 获 得 指定 行 .指定 列 的 数据 

dv. Sort = "排序 依据 的 列 名 "; // 按 照 指定 列 排序 
int num = dv. Count; // 获 得 DataView 对 象 中 的 记录 数 


8.3.2 数据 表示 层 控件 剖析 


VS2008 为 数据 显示 提供 了 多 种 控件 ,在 前 面 的 案例 中 已 经 多 次 使 用 过 GridView 控 
件 和 FormView 控件 。 对 于 ASP.NET 开发 中 常见 的 控件 ,本 节 将 进行 一 个 较为 系统 的 
总 结 。 
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1. GridView 与 DataGrid 

在 .NET 的 1.1 版 本 中 提供 了 重要 的 控件 DataGrid, 到 .NET 3. 5 后 该 控件 已 经 被 
GridView 所 取代 。 对 比 两 个 控件 ,二 者 的 用 法 和 用 途 都 非常 相似 。 主 要 具有 以 下 特点 : 
以 二 维 表格 的 形式 显示 数据 表 的 内 容 , 按 照 每 行 一 条 记录 、 每 列 一 个 字段 的 方式 
苦 现 。 
提供 分 页 编辑、 排序 等 特性 。 
提供 了 功能 强大 的 编辑 器 以 及 模板 列 , 灵 活性 强 ,内 置 事件 丰富 。 
内 置 多 种 布局 风格 ,对 于 表格 的 操作 非常 方便 。 

与 优点 相 比 , 这 两 种 控件 也 存在 着 少量 的 缺陷 。 比 如 ,个 性 化 设置 有 限 , 只 能 以 二 维 表 
格 方式 输出 数据 ,性 能 不 是 很 高 。 

GridView 可 由 DataSource 对 象 .DataTable 对 象 .DataView 对 象 和 DataSet 对 象 提供 
数据 源 。 如 果 由 DataSet 方式 提供 数据 源 , 需 要 指明 数据 表 名 称 。 

GridView 运行 的 效果 图 如 图 8-11 所 示 ,利用 
其 右上 角 的 智能 菜单 能 够 实施 绝 大 多 数 的 配置 


Al00 张 攻 军 女 199711 生物 系 生物 史 12 


功能 。 S001 张 萍 志 女 198911211 物理 系 物理 学 68 
， 。 S002 李 大 尖 2 男 1990/1/12 教育 系 教育 史 687991234 0 出险 选择 
2. DetailsView 与 FormView So03 刘 明 。 女 1990412 物理 系 物理 学 。 698721212 100 出 入 半径 


顾名思义 , DetailsView 主要 用 于 显示 某 一 记 | 和 
录 的 详细 信息 ,因此 它 常常 受到 GridView 的 控 
制 ,用 来 显示 选 定 记录 的 详细 信息 。 而 FormView 
则 用 来 制作 一 个 编辑 表单 ,可 以 便利 地 为 数据 表 输 入 内 容 。 因 此 这 两 个 控件 都 主要 用 于 处 
理 单条 项 目 ,默认 为 每 条 记录 占据 一 个 页 面 .每 个 字段 占据 一 行 的 模式 。 

DetailsView 和 FormView 都 可 由 DataSource 对 象 和 DataTable 对 象 提供 数据 源 。 另 
外 ,这 两 个 显示 对 象 都 有 智能 菜单 ,可 以 【自动 套用 格式 】,， 支持 三 种 模式 : ReadOnly、 
Insert、Edit, 可 通过 DefaultMode 属性 设置 其 初始 模式 。 为 开发 者 开发 数据 表 输 入 ,编辑 界 
面 提供 便捷 的 支持 。 

需要 指出 的 是 ,FormView 控件 允许 开发 者 重新 编辑 ItemTemplate 模板 ,可 以 重新 排 
列 各 个 字段 在 页 面 上 的 位 置 ,并 不 局 限于 每 个 字段 占据 一 行 的 模式 ,使 用 起 来 更 加 灵活 。 

DetailsView 的 显示 效果 如 图 8-12 所 示 ,FormView 的 现实 效果 如 图 8-13 所 示 。 


图 8-11 GridView 控件 的 运行 效果 图 
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张 举 军 
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生物 系 
生物 史 
12345678 

200 

量 除 者 建 
8-12 ”DetailsView 运行 效果 图 8-13 ”FormView 运行 效果 图 
3. DataList 


DataList 是 一 个 历史 较为 悠久 的 数据 显示 控件 ,从 .NET 1. 1 开始 就 已 经 存在 了 。 这 
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是 一 个 主要 用 于 数据 显示 的 控件 。 其 特点 是 拥有 强大 的 模板 特性 ,可 以 便利 地 设置 各 字段 
在 页 面 中 的 位 置 。DataList 默认 的 显示 效果 如 图 8-14 所 示 。 

DataList 对 象 的 智能 菜单 中 包含 了 “编辑 模 
板 ” 的 功能 ,而 且 支持 对 页 眉 页 脚 .ItemTemplate csdate: 1987/11 00000 
区 域 的 编辑 ,利用 它 能 够 快捷 地 设计 出 记录 布局 ie 
灵活 的 完美 页 面 。 因 

与 FormView 相 比 ,DataList 对 象 支持 在 一 “da 
个 页 面 甚 至 一 行 中 显示 多 条 记录 ,更 有 利于 大 量 内 
短 记录 数据 (每 条 记录 的 信息 量 都 较 少 ) 的 显示 任 
务 。 开 发 者 可 以 通过 修改 RepeatColumns 和 
RepeatDirection 属性 的 值 改 变 每 行 显示 记录 的 数量 和 显示 方向 。 

DataList 也 通过 其 DataSource 属性 值 所 给 出 的 字符 串 获 知 数据 源 名 称 , 然 后 才能 从 指 
定 的 DataSource 对 象 或 DataTable 对 象 中 提取 数据 。 

4. ListView 

ListView 是 以 罗列 方式 显示 记录 内 容 的 。 它 支持 以 多 种 方式 在 一 个 页 面 中 同时 显示 
多 条 记录 。 按 照 “ 平 铺 ”“ 网 格 ”"“ 项 目 符号 ”等 形式 来 布局 多 条 记录 的 显示 是 常用 的 
技巧 。 

在 创建 ListView 对 象 后 , 首要 任务 就 是 利用 智能 菜单 为 此 对 象 配置 数据 源 
DataSource, 其 数据 源 也 可 以 是 DataSource 对 象 或 DataTable 对 象 。 然 后 可 以 利用 智能 菜 
单 的 “配置 ListView” 实 施 页 面 布局 ,打开 如 图 8-15 所 示 的 对 话 框 ,可 根据 需要 选用 适合 自 
己 要 求 的 布局 形态 。 

其 左下 角 的 选项 提供 了 【启用 编辑 ]【 启 用 插入 】【 启 用 删除 3 和 【启用 分 页 等 功能 。 
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图 8-14 ”DataList 运行 效果 图 
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8-15 ”ListView 的 配置 界面 
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5. Repeater 

Repeater 控件 是 ASP.NET 中 一 直 保 留 的 一 个 控件 ,这 个 控件 为 开发 者 提供 了 一 个 充 
分 发 挥 个 性 的 平台 ,允许 开发 者 完全 自主 地 利用 代码 实施 布局 。 其 特点 是 : 

。 控件 完全 以 HTML 方式 呈现 ,更 加 个 性 化 。 

。 不 支持 分 页 ,编辑 和 排序 功能 。 

。 不 提供 默认 的 风格 , 需 手 工 编写 。 

。 主要 用 于 一 些 灵 活性 、 性 能 更 高 的 数据 展现 。 

。 相 比 之 下 ,Repeater 控件 性 能 最 好 ,但 对 开发 者 的 要 求 也 最 高 。 


候 考 是 


1. SqlConnection 是 什么 ? 在 数据 库 访问 中 居于 什么 地 位 ? 

2. SqlCommand 对 象 的 输入 ,输出 是 什么 ? 

3. 对 于 一 个 Select 命令 语句 来 讲 , SqlCommand 的 运行 结果 是 什么 ? 该 结果 有 什么 
特点 ? 

4. 什么 是 SqlDataAdapter? 在 以 SqlDataAdapter 技术 实施 数据 库 访问 的 技术 体系 中 
主要 有 哪些 控件 ? 各 居于 什么 地 位 ? 
. 什么 是 DataSet? DataSet 的 数据 从 哪里 来 ? 
. 如何 实现 DataSet DataTable .DataView 和 DataRow 之 间 的 类 型 转换 ? 
. 如 何 才能 从 DataTable 中 获取 指定 行 、 指 定 列 的 数据 ? 
. DataView 具有 查询 功能 吗 ? 如何 利用 DataView 实现 数据 查询 ? 
. 如 何 利用 SqlDataAdapter 和 DataSet 实现 记录 更 新 ? 

10. 在 SqlCommand 体系 中 ,如 何 才 能 向 指定 数据 表 中 插入 记录 ? 

11. 在 SqlDataAdapter 技术 中 ,是 如 何 实现 向 数据 表 中 插入 新 记录 操作 的 ? 

12. GridView DataGrid、FormView 可 由 哪些 数据 库 对 象 提供 数据 源 ? 

13. 在 Web 应 用 系统 中 ,数据 表示 层 控件 GridView、DataGrid、FormView、 DataList、 
ListView 有 哪些 特点 ? 各 有 什么 适应 性 ? 


仁 机 实 训 惠 


基于 第 5 章 创建 的 商品 销售 系统 数据 库 , 新 建 商品 销售 项 目 SPLINQ, 在 此 项 目 中 利用 
SqlCommand 或 者 SqlDataAdapter 完成 以 下 操作 。 

(1) 新 建 商品 信息 管理 窗 体 ShangPin, 在 其 中 添加 GridView 控件 ,重点 显示 商品 信息 
的 前 4 个 字段 ,并 为 GridView 添加 “选择 ” 列 “ 删 除 ” 列 。 设 置 GridView 为 自动 分 页 模式 ， 
每 页 显示 6 条 记录 。 

(2) 利用 “选择 ” 列 ,可 以 选 定 一 个 商品 ,并 用 ASP.NET 的 标准 控件 显示 出 被 选 定 商品 
的 详细 信息 ; 或 者 使 用 DetailsView 控件 显示 被 选 定 商 品 的 详细 信息 。 

(3) 利用 “删除 ” 列 的 按钮 ,可 以 把 被 单 击 的 商品 删除 ,而 且 要 求 在 真正 地 执行 删除 命令 


< oo Am a 
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前 先 要 核实 “您 确实 想 删除 这 个 商品 吗 ??; 只 有 客户 确实 选 定 为 “是 ”, 才 可 使 用 LINQ 技术 
把 该 商品 删除 。 

(4) 利用 模板 列 , 为 GridView 添加 CheckBox 列 , 对 于 CheckBox 列 中 被 选中 的 所 有 商 
品 , 其 进货 价 增长 2 元 。 

(5) 不 使 用 FormView 技术 ,而 是 直接 使 用 标准 控件 编写 商品 信息 输入 界面 ,然后 利用 
为 SqlDataAdapter 技术 实现 商品 信息 的 插入 。 
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学 习 要 点 

本 章 主 要 学 习 ASP.NET 程序 的 应 用 环境 配置 与 网 页 切换 的 关键 技术 。 要 求 了 解 ASP 
.NET 应 用 程序 的 machine. config 与 web. config 文件 的 用 途 、 格 式 与 相互 关系 ,了 解 Global 
.asax 文档 的 用 途 与 结构 ,了 解 网 页 信息 的 获取 与 输出 技术 .Session 和 Application 变量 的 概念 
和 用 途 、 网 页 切换 及 参数 传递 技术 等 访问 数据 库 的 传统 技术 。 本 章 要 求 重 点 关注 以 下 内 容 ， 

。 Request 命令 的 用 途 ,特别 是 Request. QueryString 和 Request 服务 器 变量 信息 的 技术 。 

。 Response 命令 的 用 途 , 特 别 是 利用 Response 实施 网 页 切换 的 技术 。 

。 Session 变量 与 Application 变量 的 概念 及 其 用 法 。 

。 以 Global. asax 文件 实现 应 用 程序 运行 控制 的 技术 。 

。 网 页 切换 过 程 中 的 参数 传递 技术 。 


8.1 Web 页 面 的 内 部 对 象 综述 

在 Web 应 用 程序 运行 时 ,ASP.NET 将 为 维护 当前 的 应 用 程序 、 用 户 与 应 用 程序 的 会 
话 、 网 站 与 客户 机 状态 信息 而 组 织 了 一 批 管理 型 的 类 和 特殊 文档 ,这 些 文档 对 于 管理 动态 网 
站 发 挥 着 重要 的 作用 。 

ASP.NET 页 框架 包含 了 一 系列 封装 上 下 文 信息 的 类 。 在 代码 中 可 以 使 用 这 些 类 的 实 
例 来 访问 内 部 对 象 ,获取 与 服务 器 或 客户 机 相关 的 信息 。 表 9-1 列 出 了 常用 的 一 些 内 部 对 
象 以 及 与 生成 这 些 对 象 相关 的 类 。 


表 9-1 ASP .NET 页 框架 中 常用 的 内 部 对 象 


对 象 名 说 明 ASP.NET 的 类 
Response 提供 对 当前 页 的 输出 流 的 访问 HttpResponse 
Request 提供 对 当前 页 的 请 求 信息 的 访问 ,获取 外 部 变量 包含 的 信息 HttpRequest 
Context 提供 对 整个 上 下 文 信息 (包括 请 求 对 象 ) 的 访问 HttpContext 
Server 公开 可 以 用 于 在 页 之 间 传 输 控件 的 实用 工具 方法 ,例如 对 HttpServerUtility 

HTML 文本 进行 编码 ,解码 等 


Application 提供 对 作用 于 所 有 会 话 的 应 用 程序 范围 的 方法 、 事 件 的 访 HttpApplicationState 
问 ,主要 用 于 提供 全 局 范围 内 的 共享 变量 

Sesssion 为 当前 用 户 的 会 话 提供 信息 ,主要 用 于 为 应 用 程序 标记 提供 ”HttpSessionState 
访问 者 的 个 人 信息 

Trace 提供 要 在 HTTP 页 面 输出 中 显示 的 跟踪 与 诊断 消息 的 方法 。 TraceContext 
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@3 HTTP 请 求 与 响应 对 象 


HTTP 请 求 与 响应 对 象 就 是 信息 的 输入 与 输出 对 象 , 主要 由 两 个 关键 的 类 生成 ， 
Response 和 Request。 其 中 的 Response 负责 输出 ,而 Request 则 负责 输入 。 


9.2.1 Response 对 象 
Response 对 象 用 于 向 客户 端 发 送信 息 ,常见 的 属性 和 方法 见 表 9-2。 


表 9-2 ”Response 对 象 的 常用 属性 与 方法 


属性 名 或 方法 用 途 


如 果 取 值 true, 表 示 打 开 输 出 缓冲 区 ,而 且 服 务 器 在 数据 处 理 过 程 中 使 用 缓冲 
区 。 缓 冲 区 已 满 或 数据 处 理 完毕 , 才 向 客户 端 浏览 器 发 送信 息 


Er 如 果 取 值 false, 表 示 关 闭 输出 缓冲 区 。 服 务 器 在 处 理 数据 时 ,直接 把 处 理 结果 发 
送 到 客户 端 浏览 器 

Clear() 方 法 清空 输出 缓冲 区 ,只 在 Buffer==true 时 有 效 

End() 方 法 终止 ASP.NET 应 用 程序 的 输出 

Flush() 方 法 立即 向 客户 端 发 送 输出 缓冲 区 中 的 所 有 信息 ,清空 缓冲 区 


Redirect(URL) 方 法 | 页 面 重 定向 ,立即 转向 指定 的 网 页 
Write( 字 符 串 ) 方 法 “| 在 页 面 上 输出 字符 串 信息 
AppendToLog() 方 法 | 将 自 定义 日 志 信息 添加 到 IIS 日 志文 件 中 


在 具体 开发 中 ,Response 主要 包括 以 下 3 种 使 用 方式 。 

1. Response. Write( 字 符 串 ) 

“Response. Write( 字 符 串 )” 用 于 将 字符 型 常量 .字符 型 数组 .字符 型 变量 的 值 送 到 客户 
端 输出 。 在 ASP 技术 发 展 的 早期 ,Response. Write 是 一 个 非常 重要 的 方法 ,负责 整个 逻辑 
代码 部 分 的 输出 。 然 而 在 ASP.NET 开发 技术 中 ,Response. Write 已 经 不 是 逻辑 代码 部 分 
输出 信息 的 主要 方法 。 在 ASP.NET 技术 时 代 , 由 于 Response. Write 不 易 控制 数据 的 输出 
位 置 和 难以 直接 通过 【属性 了 面板 设置 样式 ,更 多 的 开发 者 更 愿意 在 Web 窗 体 中 放置 一 个 
Label 对 象 ,然后 通过 为 Label. Text 赋值 而 达到 输出 字符 型 信息 的 目的 。 

在 Response. Write 命令 的 参数 中 ,如 果 其 字符 串 是 一 行 包 括 JavaScript 代码 或 
HTML 代码 的 程序 , Web 服务 器 就 会 把 这 段 代码 直接 发 送 到 客户 的 浏览 器 中 ,客户 端 浏览 
器 会 自动 地 执行 这 段 代码 ,达到 一 种 特定 的 效果 。 

【 例 9-1】 以 警示 框 的 形式 输出 一 段 警告 性 文字 。 


Response. Write("< Script > alert( ' 不 允许 输入 0 值 ! ') ;</Script >"); 
【 例 9-2】 以 表格 形式 输出 变量 的 值 。 


String dat = "<Table><Tr><td>"+T1.Text+ "</td><td>" + T2. Text + "</td></Tr>" 
dat= dat+ "<Tr><td>"+T3.Text+ "</td><td>" + T4.Text + "</td></Tr></Table>" 
Response. Write(dat); 
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在 例 9-1 中 ,Response. Write 输出 的 是 一 个 JavaScript 语句 ,利用 此 语句 可 以 实现 输出 
警示 框 的 目的 。 在 例 9-2 中 ,Response. Write 输出 的 是 一 段 HTML 代码 ,负责 绘制 一 个 2 
行 2 列 的 表格 ,分 别 输出 Web 窗 体 对 象 T1.T2.T3 和 T4 的 Text 值 。 

注意 : Response. Write 的 参数 是 单一 的 字符 串 形式 。 如 果 要 输出 的 信息 比较 复杂 ,其 
至 其 中 包括 引号 。 建 议 先 用 字符 串 处 理 语句 进行 预 处 理 , 然 后 再 输出 。 对 于 其 中 的 多 重 引 
号 ,建议 内 层 引 号 使 用 单 引 号 。 

2. Response. WriteFile( 文 件 名 称 ) 

“Response. WriteFile( 文 件 名 称 )” 用 于 把 指定 的 文件 送 到 客户 机 的 浏览 器 上 输出 ,其 
目的 是 快速 地 发 布 一 段 文字 内 容 。 例 如 


Response. WriteFile( "m1. txt"); 


其 含义 是 把 存储 在 当前 文件 夹 中 的 文件 ml. txt 的 内 容 输出 到 客户 端的 浏览 器 上 。 

3. Response. Redirect(URL) 

“Response. Redirect(URL)" 作 用 是 把 客户 端 重新 定向 到 新 的 URL, 即 让 客户 的 浏览 
器 跳 转 到 指定 的 新 网 页 上 。URL 信息 既 可 以 使 用 绝对 地 址 ,也 可 以 使 用 相对 地 址 。 

【 例 9-3】 浏览 器 从 当前 位 置 跳 转 到 北京 师范 大 学 主页 (www. bnu. edu. cn)。 


Response. Redirect("http://www.bnu.edu.cn" ); 
【 例 9-4】 浏览 器 从 当前 位 置 跳 转 到 服务 器 当前 文件 夹 中 的 xuesheng. aspx 页 面 上 。 
Response. Redirect( "xuesheng. aspx" ); 


Response. Redirect 支持 携带 参数 的 网 页 跳 转 。 假 设 showData. aspx 是 显示 某 一 条 新 
闻 详 细 内 容 的 aspx 程序 ,那么 开发 者 常常 使 用 


Response. Redirect( "showData. aspx?ID = 5"); 


来 表示 要 显示 第 5 条 新 闻 的 详细 内 容 。 这 种 方式 表示 携带 参数 执行 showData 程序 ,这 里 
“7” 后 面 的 内 容 就 是 网 页 的 参数 。“ID” 是 参数 名 称 ,“5” 是 参数 的 值 。 当 然 ,参数 名 称 和 参 
数值 都 可 由 开发 者 根据 需要 任意 定义 。 

假设 存在 一 个 显示 新 闻 标题 的 GridView 对 象 gyNews, 那 么 语句 


Response. Redirect ("showData. aspx?ID = " + gvNews. SelecteValue. ToString()); 


则 表示 要 显示 出 GridView 中 被 用 户 选中 的 那 条 新 闻 的 详细 内 容 。 
4. 对 于 信息 输出 的 示例 
(1) 输出 普通 文本 
响应 按钮 btnTxt( 输 出 普通 文本 按钮 ) 的 Click 事件 的 源 代码 如 图 9-1 所 示 。 
单 击 按钮 btnTxt 后 ,执行 的 效果 如 图 9-2 所 示 。 


49: protected void btnixt_Click(object sender, Eventhrgs e) 
| t 
Response. Write(" 不 允许 输入 数值 0!"); 


图 9-1 Response. Write 输出 字符 串 的 源 代码 
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不 允许 输入 数值 0 


图 9-2 Response. Write 输出 字符 串 的 效果 图 


(2) 输出 警示 性 信息 
响应 按钮 btnJsxx( 输 出 JavaScript 警示 框 按钮 ) 的 Click 事件 的 源 代码 如 图 9-3 所 示 。 


Response-Writet"<script>alert( 不 允许 输入 数值 0! ') ;</scripth"); 


寺 protected void btnJsxx_Click(object sender, Eventhrgs e) 
| { 
} 


9-3 ”Response. Write 输出 JavaScript 程序 的 源 代码 


单 击 按钮 btnJsxx 后 ,执行 的 效果 图 如 图 9-4 
所 示 。 

(3) 输出 ml. txt 文件 的 内 容 

响应 按钮 btnOut( 输 出 指定 文件 的 内 容 按钮 ) 的 
Click 事件 的 源 代 码 如 图 9-5 所 示 。 

运行 后 将 在 屏幕 上 显示 出 ml. bt 文件 的 内 容 。 图 94 Response Write 输 由 JavaScript 

(4) 跳 转 到 清华 大 学 主页 程序 的 效果 图 

响应 按钮 btnTsinghua( 跳 转 到 清华 大 学 主页 按 
钮 ) 的 Click 事件 的 源 代码 如 图 9-6 所 示 。 


L239 protected void btnOut_Click (object sender, Eventhrgs e) 
24 { 

25 

26 


Response, WriteFile ("nl, txt"); 


图 9-5 Response. WriteFile 输出 指定 文件 内 容 的 源 代码 


59 protected void btnTsinehua Click (object sender, EventAres e) 


{ 
61 引 Response. Redirect ("http:/ /wn tsinghua, edu .cn ) ; 
62 } 


9-6 ”Response. Redirect 跳 转 到 指定 网 页 的 源 代码 


9.2.2 Request 对 象 


Request 对 象 用 于 从 网 页 以 外 的 渠道 获取 信息 ,包括 获取 客户 端的 表单 数据 、 获 取 前 级 
程序 调用 本 网 页 时 携带 的 参数 .获取 服务 器 或 客户 端的 状态 信息 等 。 常 见 的 用 法 主要 包括 
以 下 4 种 使 用 方式 。 

1. Request. QueryString ("参数 名 ") 

“Request. QueryString( "参数 名 ")” 用 于 从 前 级 调用 语句 的 参数 中 获得 信息 。 

在 前 面 的 例子 中 曾经 谈 及 应 用 程序 通过 执行 “Response. Redirect ("showData. aspx? 
ID=5")” 方 式 携带 参数 执行 showData 程序 , 即 上 级 程序 发 出 了 携带 参数 ID 执行 
showData 程序 的 需求 。 那 么 showData. aspx 程序 必须 要 接收 这 个 参数 的 值 并 在 程序 中 使 
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之 发 生 作用 。 为 此 需要 在 showData. aspx 程序 中 使 用 接受 参数 数值 的 语句 : 
String xx = Request. QueryString["ID"]; 


这 里 ,QueryString 后 面 括号 内 的 ID 是 参数 的 名 称 ,应 与 前 级 程序 指定 的 参数 名 称 一 
致 ,而 xx 是 开发 者 定义 的 内 存 变 量 名 称 , 可 根据 需要 任意 定义 。 在 此 例 中 , 当 showData 程 
序 获取 了 xx 变量 后 ,就 可 以 根据 xx 的 值 来 确定 显示 哪 一 条 消息 的 内 容 了 。 

2. Request. Form ("表单 域名 称 ") 

“Request. Form[ "表单 域名 称 "]” 的 功能 是 从 前 级 程序 的 HTML 表单 中 获得 表单 变量 
的 值 。 如 果 调 用 此 程序 的 前 级 程序 内 包含 了 一 个 HTML 表单 而 且 是 通过 表单 提交 来 调用 
本 程序 的 ,那么 在 本 程序 中 就 需要 使 用 命令 : 


String xx = Request. Form( "表单 域名 称 "); 


来 获取 客户 端 提交 的 数据 。 

注意 ; 本 命令 仅 用 于 获取 客户 端的 HTML 表单 提交 的 数据 ,不 包括 Web 窗 体 控 件 。 
由 于 在 ASP.NET 中 主要 使 用 Web 窗 体 控件 设计 程序 ,而 Web 窗 体 控件 的 输入 值 可 直接 
被 后 台 的 逻辑 代码 (本 书 为 C 井 代码 ) 调 用 ,不 需要 专门 的 命令 索取 。 因 此 本 命令 在 ASP 
.NET 时 代 已 基本 被 废弃 ,但 在 ASP 程序 和 JSP 程序 中 曾经 被 广泛 地 应 用 。 

3. 获取 客户 端 状态 信息 

在 Web 应 用 程序 开发 中 ,获取 服务 器 及 客户 端的 信息 是 常规 工作 。 常 见 的 用 法 主要 有 
以 下 命令 ， 


Request. Browser. Platform // 获 得 客户 端 计算 机 安装 的 操作 系统 名 称 
Request. Browser. Type // 获 得 客户 端 浏览 器 的 类 型 

Request. Browser. MinorVersion // 获 得 客户 端 浏览 器 的 版 本 号 

Request. UserHostAddress // 获 得 客户 机 的 IP 地 址 


4. 获取 服务 器 状态 信息 
在 ASP 系列 应 用 程序 的 开发 中 ,还 可 以 通过 服务 器 端 变量 获取 系统 的 状态 信息 。 命 令 
格式 如 下 : 


Request. ServerVariables[" 变 量 名 称 "] ; 
常见 的 ServerVariables 变量 如 表 9-3 所 示 。 
表 9-3 常见 的 ServerVariables 变量 及 其 含义 


变量 名 -4 
http_user_agent HTTP 的 用 户 端 代 理 
remote_addr 客户 机 的 IP 地 址 
remote_host 客户 机 的 主机 名 ,一 般 也 是 卫 地址 
Tequest_method 数据 获取 方法 
server_name 服务 器 名 称 
server_port 服务 器 端口 
server_software 服务 器 端的 系统 软件 


Local_Addr 服务 器 端的 IP 地址 
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5. Request 获取 信息 示例 
(1) 获取 客户 端 状态 信息 
响应 按钮 bmClient( 获 取 访 问 者 的 客户 端 信息 按钮 ) 的 Click 事件 的 源 代码 如 图 9-7 所 示 。 


238 protected void btnClient_Click(object sender, Eventhrgs e) 
| 1 
25j Response. Write(" 用 户主 机 名 :" + Request. UserHostName + "<br>"); 
269 Response. Writel" 客 户 机 地 址 :" + Request. UserHostAddress + "<br》"); 
279 Response. Write(" 客 户 端 操作 系统 :" + Request. Browser. Platforn + " <br》"); 
28| Response. Write 器 版 " + Request. Browser, MinorYersion + "<br>"); 
29| Response. Write ("浏览 器 类 型 + Request. Browser. Type + " Cbr>"):; 
30 } 


9-7 以 Request 获取 客户 端 状态 信息 的 源 代码 


单 击 按钮 btnClient 后 ,执行 的 效果 图 如 图 9-8 所 示 。 

(2) 获取 服务 器 状态 信息 

响应 按钮 btnServer( 获 取 服 务 器 状态 信息 按钮 ) 的 Click 事 
件 的 源 代码 如 图 9-9 所 示 。 

单 击 按钮 btnServer, 程 序 执行 后 的 效果 如 图 9-10 所 示 。 

由 于 最 后 一 个 变量 Server_software 没有 返回 值 。 因 此 在 
结果 中 只 看 到 了 6 行 信息 。 因 为 本 程序 只 在 程序 设计 的 主机 进行 了 测试 ,所 以 客户 机 的 名 
称 和 1IP 地 址 都 是 本 机 地 址 127. 0. 0. 1。 系 统 以 POST 模式 传递 数据 ,服务 器 名 称 为 
localhost, 使 用 端口 63460 进行 了 Web 服务 。 


用 户主 机 名 :127.0.0.1 


9-8 ”Request 获取 到 的 
客户 端 信息 


protected void btnServer_Click(object sender, Eventhrgs e) 
t 


Response. Write (Request. ServerYariables["http_user_agent"] + "<br>"); 
Response. Write (Request. ServerVariables["remote_addr"] + "<br>"); 
Response. Write (Request. ServerVariables["renote_host"] + "<br>"); 
Response. Write (Request. ServerVariables["request_method"] +“<br>") ; 
Response. Write (Request. ServerVariables["server name"] + "《br>") ; 
Response, Write (Request. ServerYariables["server_port"] + "<br>"): 


9-9 以 Request 获取 服务 器 状态 信息 的 源 代码 


9-10 通过 服务 器 变量 获取 的 信息 


至 于 使 用 Request. QueryString 方式 获取 数据 的 方式 ,将 在 讲授 网 页 参数 传递 的 部 分 
给 予 详细 示例 。 


63 Application 与 Session 


9.3.1 ASP.NET 应 用 程序 中 的 变量 及 作用 域 
在 一 个 ASP.NET 的 应 用 程序 系统 中 , 绝 大 多 数 的 内 存 变量 在 逻辑 代码 (C# ) 部 分 定 
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义 。 例 如 在 方法 内 部 定义 的 变量 ,其 作用 域 就 是 该 方法 体 ,一 旦 离开 此 方法 体 ,该 变量 就 自 
动 被 系统 回收 ; 定义 于 代码 块 的 变量 (常用 using()1)} 来 声明 一 个 代码 块 ) ,其 作用 域 就 是 这 
个 代码 块 ; 同 理 ,定义 在 class 层次 内 \ 不 属于 任何 一 个 方法 的 变量 被 称 为 成 员 变量 ,其 作用 
域 为 这 个 网 页 。 总 之 ,在 ASP.NET 逻辑 代码 中 定义 的 内 存 变量 尽管 可 能 很 多 ,但 没有 一 个 
作用 域 超过 该 网 页 的 变量 。 

然而 ,Web 应 用 系统 常常 由 多 个 网 页 组 成 ,这 些 网 页 中 应 该 有 一 些 需 要 共同 维护 的 信 
息 。 这 些 信息 大 臻 上 可 以 被 分 为 两 类 : 其 一 是 隶属 于 整个 应 用 程序 ,能 够 被 所 有 访问 者 共 
享 的 信息 ,比如 网 站 的 访问 量 计数 器 变量 ; 其 二 是 隶属 于 访问 者 但 可 以 贯穿 于 多 个 网 页 之 
间 的 变量 。 

第 一 类 变量 贯穿 于 整个 应 用 程序 ,在 网 站 服务 中 一 直 有 效 ,能 够 被 所 有 用 户 分 享 。 从 其 
对 程序 的 覆盖 范围 对 用 户 的 覆盖 范围 .存在 时 间 三 个 维度 看 ,这 种 变量 在 整个 应 用 系统 的 
运行 期 内 针对 全 体 用 户 一 直 有 效 。 此 类 针对 一 个 以 名 称 命名 的 变量 ,在 整个 应 用 系统 中 只 
有 一 个 。 这 种 变量 被 称 为 Application 变量 ,由 Application 对 象 负责 管理 。 

第 二 类 变量 贯穿 于 用 户 的 一 次 会 话 过 程 ,可 以 在 网 站 中 的 多 个 网 页 中 有 效 。 此 类 针对 
以 一 个 名 称 命名 的 变量 ,对 不 同 的 用 户 会 对 应 不 同 的 内 存 空 间 ,允许 取 不 同 的 数值 。 从 其 对 
程序 的 覆盖 范围 ,对 用 户 的 覆盖 范围 存在 时 间 三 个 维度 看 ,这 种 变量 的 值 只 在 一 次 会 话 期 
间 针 对 登录 用 户 有 效 。 一 旦 用 户 结束 会 话 或 者 长 时 间 没 有 操作 ,该 用 户 在 此 变量 上 的 值 就 
会 被 取消 。 这 种 变量 被 称 为 Session 变量 ,由 Session 对 象 负责 管理 。 


9.3.2 Session 对 象 


1. 什么 是 Session 变量 

Session 变量 是 被 标记 为 Session 的 变量 ,隶属 于 每 个 在 线 用 户 , 作 用 域 为 用 户 在 线 期 
间 , 可 以 跨 页 面 存在 。 一 个 带 Session 变量 的 站 点 ,会 为 每 个 访问 者 建立 一 个 Session 实例 ， 
然后 把 其 Session 变量 ID 及 其 取 值 都 存储 到 他 的 Session 实例 中 。 由 于 Session 实例 是 属 
于 在 线 用 户 的 ,一 个 用 户 对 于 Session 变量 的 修改 ,不 会 被 其 他 用 户 知道 。Session 变量 通 
常 被 用 作用 户 身份 管理 。 

Session 变量 是 ASP .NET 体系 中 用 于 存储 用 户 信息 的 特殊 对 象 。 例 如 Session 
["xsno"] 表 示 变 量 xsno 被 标记 为 Session 类 型 的 变量 。 在 用 户 访问 定义 Session[ "xsno" 
的 网 页 时 ,Session 对 象 会 对 每 个 在 线 用 户 都 产生 一 个 特定 的 实例 ,在 实例 中 存储 针对 该 用 
户 的 特定 值 。 用 户 一 旦 离开 此 站 点 ,该 用 户 的 Session 实例 会 自动 消失 。 即 Session 实例 在 
客户 登录 包含 Session 变量 的 页 面 时 建立 ,在 此 客户 离开 该 站 点 时 消亡 。A 用 户 Session 实 
例 不 会 与 B 用 户 的 Session 实例 交叉 .冲突 。 

除了 Session 实例 到 期 .Session 被 终止 ,关闭 浏览 器 和 客户 离开 站 点 ,Session 实例 不 会 
消逝 。 也 就 是 说 ,如 果 用 户 在 访问 站 点 的 某 一 页 面 时 创建 了 一 个 Session 实例 ,即使 用 户 离 
开 了 这 个 页 面 ,只 要 他 没 离开 此 站 点 ,而 且 实 例 没有 到 期 和 被 终止 ,那么 它 将 一 直 存 在 。 
因此 在 动态 网 站 开发 中 ,Session 变量 经 常 被 用 于 定义 用 户 的 全 局 变量 和 标记 用 户 身份 。 
例如 ,信息 系统 开发 中 经 常 需要 利用 Session 变量 记 下 登录 者 的 用 户 名 ,操作 权限 ,以 便 限 
定 该 用 户 只 能 查询 其 个 人 信息 ,而 且 能 在 他 更 新 数据 时 ,自动 记录 用 户 名 ,保留 操作 
痕迹 。 
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总 之 ,Session 实例 只 属于 创建 它 的 用 户 , 其 他 用 户 也 只 能 使 用 他 自己 的 实例 ; Session 
实例 可 以 跨 页 面 存在 ,但 Session 实例 不 可 以 跨 站 点 存在 。Session 实例 常常 被 Session 对 
象 以 Cookie 的 方式 写 到 客户 机 上 。 

2. Session 变量 的 使 用 

1) 创建 Session 实例 

创建 Session 变量 的 一 般 格式 为 : 


Session[ "变量 名 "] = 变量 值 ; 
例如 ,“Session[ "loginno"] 二 login. Text; ”将 创建 值 为 “login. Text” 的 Session 变量 


Loginno。 

Session 变量 将 在 用 户 访问 包含 此 变量 的 网 页 时 被 实例 化 。 每 个 访问 者 都 会 在 访问 此 
网 页 时 针对 此 Session 变量 创建 一 个 自己 的 Session 实例 。 

2) Session 对 象 的 属性 

Session 对 象 的 重要 属性 有 3 个 : SessionID .Timeout 和 Mode。 

其 中 ,SessionID 是 Session 的 唯一 标志 号 ; 而 Timeout 的 功能 是 设置 Session 实例 的 
有 效 期 (以 分 钟 为 单位 ); 通过 Mode 属性 可 以 获取 当前 Session 的 模式 。 

例如 ,Session. Timeout= 二 120” 表 示 设 定 Session 实例 的 有 效 期 为 120 分 钟 ,Session 实 
例 在 被 用 户 激发 .创建 后 的 第 120 分 钟 时 会 自动 消亡 。 

3) Session 对 象 的 方法 

Session 对 象 的 最 常用 方法 是 abandon, 其 功能 是 清除 Session 的 实例 ,使 Session 无 效 。 
Session. Abandon 表示 执行 此 命令 的 用 户 的 所 有 Session 变量 全 部 消亡 。 在 信息 系统 开发 
中 , 常 把 此 方法 用 在 注销 系统 时 ,利用 它 注销 用 户 的 登录 身份 。 

对 于 Session 的 复杂 应 用 ,将 会 在 第 10 章 “ 登 录 模块 设计 ”中 进行 详细 的 探索 。 

注意 : 由 于 针对 Session 变量 每 个 访问 者 都 要 创建 独立 的 实例 。 因 此 ,对 访问 量 较 大 的 
Web 服务 器 来 讲 , 应 尽 可 能 减少 Session 变量 的 使 用 ,以 免 因 Session 实例 过 多 而 导致 服务 
器 性 能 下 降 。 

Session 使 用 的 变量 名 称 不 区 分 大 小 写 , 因 此 不 要 使 用 大 小 写字 母 来 区 分 变量 。 

3. 应 用 Session 变量 的 示例 

对 于 如 图 9-11 所 示 的 登录 界面 ,如 果 登 录 成 功 ,就 创建 两 个 Session 变量 ,可 以 在 该 用 
户 的 会 话 期 中 有 效 。 

假设 图 9-11 中 的 两 个 文本 框 对 象 的 ID 依次 为 uname 和 pswd 民 登录 按钮 的 ID 为 
btnLogin, 而 且 pswd 的 TextMode 为 password。 当 用 户 输入 合法 的 用 户 名 和 正确 的 密码 
后 ,系统 应 该 创建 两 个 Session 变量 ,分 别 保存 登录 用 户 
的 用 户 名 和 登录 状态 。 登 录 代码 如 图 9-12 所 示 。 
注意 : 本 例 中 暂时 假设 用 户 名 为 MaXiulin、 密 码 为 
mxll23 为 合法 用 户 。 在 实际 Web 应 用 系统 的 设计 中 , 合 
法 的 用 户 名 和 密码 应 该 从 数据 库 的 用 户 表 中 获取 ,只 有 
通过 合法 性 验证 的 用 户 才 被 创建 Session 变量 。 


9-11 输入 用 户 名 和 密码 的 
界面 图 
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protected void btnLogin Click(object sender，Eventargs e) 


String yhn = uname. Text.Trim() ; // 获 取 输 入 的 用 户 名 信息 
String psd = pswd. Text. Trin() ; // 获 取 输 入 的 密码 信息 
证 (yhn == "NMaXiulin" && psd == "mx1123") 

[ 


Session["lognane"] = yhn: 

// 创 建 名 字 为 lognane 的 Session 变 量 , 记录 登录 名 
Session["logState"] = "OK" 

// 创 建 名 字 为 lo0g5tate 的 Session 变 量 ， 记录 登 录 状态 | 
Response.Write(" 欢 迎 光临 ! ") ; 


图 9-12 把 文本 框 信息 保存 到 Session 中 
9.3.3 Application 对 象 


1. Application 对 象 的 概念 

默认 情况 下 ,一 个 项 目 中 的 所 有 ASP .NET 文档 构 
成 一 个 Web 应 用 系统 。 当 这 个 应 用 系统 开始 提供 服务 时 ,允许 多 个 客户 同时 访问 这 个 
Web 应 用 系统 。 为 了 让 所 有 的 访问 者 都 能 够 共享 一 些 数据 ,可 以 把 这 些 数 据 的 存储 对 象 定 
义 为 Application 类 型 ,由 Application 对 象 统一 管理 。 

定义 为 Application 类 型 的 变量 在 整个 应 用 程序 范围 内 对 所 有 访问 者 有 效 。 所 有 的 访 
问 者 共享 同一 个 内 存 区 域 中 的 变量 。 

2. Application 变量 的 应 用 

1) 创建 Application 变量 

创建 Application 变量 的 一 般 格式 为 : 

Application[ "变量 名 "] = 变量 值 ; 

例如 ,“Application["Counter"] 二 128;” 将 创建 值 为 128 的 Counter 变量 ,该 变量 为 
Applieation 变量 。 

Application 变量 将 在 首次 运行 此 代码 时 实例 化 ,不 论 有 多 少 访问 者 都 共用 一 个 实例 。 

2) Application 变量 的 应 用 

由 于 Application 对 象 是 同一 个 应 用 程序 中 所 有 的 动态 网 页 所 共有 的 ,所 以 如 想 对 它 进 
行 操作 ,就 必须 先 锁定 Application ,操作 完成 后 立即 解除 锁定 。 

假设 想 用 Counter 记录 网 站 的 访问 总 人 次 (网 站 访问 计数 器 ) ,那么 只 须 把 下 列 语句 添 
加 到 用 户 登录 的 代码 段 中 : 

Application. Lock( ); 

Application[ "Counter"] = (int)Application["Counter"] +1; 


Application. UnLock( ); 
T1. Text = Application[ "Counter" ]; 


注意 : 为 了 保证 Web 应 用 程序 的 并 发 能 力 , 应 尽量 减少 Application 对 象 的 锁定 时 间 。 


@.4 Web 应 用 程序 的 配置 文档 


在 Web 应 用 程序 中 ,对 页 面 对 象 的 响应 由 各 网 页 的 代码 隐藏 页 中 存储 的 逻辑 代码 负 
责 , 诸 如 btn_Click 等 形式 的 诸多 方法 高 效 地 处 理 了 动态 网 页 中 的 绝 大 多 数 业务 活动 。 然 
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而 对 于 整个 程序 的 运行 环境 构造 和 针对 整个 应 用 程序 的 一 些 事件 的 响应 , 则 不 是 某 一 动态 
网 页 内 部 的 代码 隐藏 页 能 够 解决 的 。 因 此 ,与 Web 应 用 程序 的 运行 环境 配置 和 针对 应 用 程 
序 级 别 事件 的 处 理 需 要 有 专门 的 机 制 。 在 ASP.NET 3. 5 体系 中 ,提供 了 两 个 专门 的 配置 
文档 : 其 一 是 machine. config 文档 ,位 于 .NET Framework 文件 夹 的 CONFIG 文件 夹 中 ; 
其 二 是 Web. config 文档 ,位 于 项 目 文件 夹 中 ,这 两 个 文件 主要 保存 一 些 系统 配置 信息 ,为 应 
用 程序 的 运行 设置 工作 环境 ; 另外 ,还 有 一 个 全 局 性 的 应 用 系统 响应 程序 ,名 称 是 global. 
asax 文档 ,主要 处 理 与 应 用 程序 相关 的 事件 ,并 为 响应 应 用 程序 级 别 的 事件 准备 方法 。 


9.4.1 配置 文档 Web.config 和 machine. config 


1. 什么 是 ASP .NET 配置 文档 

Web 站 点 的 配置 信息 文档 ,用 于 保存 应 用 程序 运行 环境 的 一 些 信息 。 其 目的 是 为 应 用 
程序 的 运行 提供 高 效 的 、 合 理 的 运行 环境 ,通常 采用 XML 格式 的 文档 。ASP .NET 的 配置 
文档 由 两 个 文件 构成 ,分 别 为 machine. config 和 web. config 文档 ,两 个 文档 的 结构 相同 , 作 
用 基本 相同 ,都 是 XML 格式 的 文档 ,都 是 为 ASP.NET 应 用 系统 的 运行 环境 进行 设置 ,为 
ASP.NET 的 运行 提供 一 个 有 效 的 环境 。 

文档 machine. config 位 于 .NET Framework 文件 夹 的 CONFIG 文件 夹 下 ,被 存放 在 系 
统 盘 的 Windows 文件 夹 下 的 子 文件 夹 Microsoft .NET\ Framework 之 下 ,而 Web. config 
位 于 项 目 文件 夹 之 中 。 从 两 个 文件 的 存放 位 置 可 以 看 出 ,machine. config 是 一 个 全 局 性 配 
置 文档 ,为 Web 服务 器 的 所 有 项 目 提供 配置 信息 ; Web. config 是 一 个 项 目 内 部 的 配置 文 
档 ,用 于 为 当前 项 目 提供 独特 的 配置 信息 。 通 常 ,Web. config 首先 从 machine. config 中 继 
承 配置 信息 ,然后 才 使 用 自己 独特 的 配置 信息 。 

为 了 提高 扩展 性 和 灵活 性 ,ASP.NET 允许 一 个 应 用 程序 配置 多 个 Web. config 文档 ， 
而 且 Web. config 文档 也 不 一 定 放 在 应 用 程序 的 根 目录 下 。 在 这 种 机 制 下 ,系统 允许 每 个 子 
目录 都 可 以 有 自己 独立 的 配置 文档 。 当 然 , 如 果 某 个 子 目 录 没有 自己 的 Web. config, 它 就 
可 以 从 自己 的 上 级 目录 中 继承 配置 信息 。 如 果 针 对 某 一 设置 项 有 多 种 设置 , 则 以 最 邻近 的 
Web. config 文档 提供 的 配置 值 覆 盖 其 他 值 。 

2. Web. config 文档 的 结构 

打开 一 个 最 基础 的 Web. config 文档 ,会 发 现 它 是 XML 文档 结构 ,其 中 的 内 容 由 许多 
节 组 成 ,而 每 个 节 的 下 面 又 可 以 包含 更 细小 的 节 。 因 此 , Web. config 是 一 种 由 节点 构成 的 
树 状 结构 ,如 图 9-13 所 示 。 

图 9-13 给 出 了 一 个 Web. config 文档 的 局 部 内 容 , 从 这 个 图 中 可 以 明显 地 看 出 其 树 形 
结构 的 性 质 。Web. config 中 包含 了 许多 配置 节 , 这 些 节 的 绝 大 部 分 都 是 通用 的 。 另 外 ,也 
允许 开发 者 自行 定义 所 需要 的 节 , 并 加 上 特定 的 节 标 记 。 

3. 以 Web. config 管理 会 话 状态 

在 9. 3. 2 节 中 对 Session 变量 进行 了 讨论 ,明确 指出 Session 实际 上 是 一 种 面向 用 户 
的 会 话 。 为 了 对 访问 者 进行 管理 ,ASP.NET 系统 提供 了 针对 访问 者 的 Session 变量 与 实 
例 的 概念 ,并 允许 开发 者 通过 Global. asax 文档 对 会 话 的 启动 与 结束 编制 专门 的 处 理 
代码 。 
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li ?xm]l version="1.0" encoding="utf-8"?> 
| 


configuration> 


《sectionGroup name=" system. web. extensions" type="System. Web.Configuration, Sy| 


a 
和 

9 《configSectIons> 

Gi 

TH 《sectionGroup name="scripting" type="System. Web.Configuration. ScriptingSec| 


B: Csection name=" scriptResourceHandler" type="System. YWeb.Configuration. Scr| 
9 《sectionGroup name="webServices" type=" System. Web.Configuration. Scriptin 
10: 《section name=" jsonSerialization" type="System. Web.Configuration. Scrip 
lli 《section name="profileService" type="Systen. Web.Configuration. Scriptin 
12 《section name="authenticationService" type="System. Web.Configuration.s 
13: 《section name="roleService" type="Systen. Web.Confieguration, ScriptingRol 
14ir /sectionGroup> 

15i- /sectionGroup> 

16ir /sectionGroup> 

Ti /configSections> 

18s 

19: 《appSettingsA> 
20 comectionStrings/> 
21 


20 Kes ens oy 

L Cl 
设置 compilation debug="true” 可 将 调试 符号 插入 已 编译 的 页 面 中 。 但 由 于 这 
影响 性 能 ， 因 此 只 在 开发 过 程 中 将 此 值 设置 为 true。 


26ir —> 

27 浊 <compilation debug="false"> 

28 

299 assemblies> 

30 《add assembly="System.Core, Yersion=3,5.0,0, Culture=neutral, Publicke: 
31i 《add assembly="Systenm. Data, DataSetExtensions, Yersion=3,5,0,0, Culture 
32 《add assembly="System. Web. Extensions, Yersion=3.5.0.0, Culture=neutral 
33 《add assembly="System. Xnml.Ling, Version=3.5.0.0, Culture=neutral, Pub]| 
34 </assemblies> 


9-13 Web. config 文档 的 内 容 及 结构 


既然 Session 如 此 重要 ,作为 Web 服务 器 ,应 该 提供 一 种 专门 的 机 制 或 者 配置 一 种 合适 
的 运行 环境 支持 Session 技术 的 应 用 。 为 此 ,在 Web. config 文档 中 专门 配置 了 一 个 小 节 ， 
用 于 对 会 话 配 置 合适 的 运行 环境 一 一 这 就 是 SessionState 配置 。 

1) mode 属性 

mode 属性 用 于 说 明 Session 的 存储 类 型 ,主要 有 以 下 4 种 方式 。 

。 mode= "off" 一 一 表示 关闭 Session, 不 采用 Session 技术 。 

。 mode 二 "InProc" 一 一 表示 将 Session 存放 于 本 地 服务 器 上 。 

。 mode="SQLServer" 表示 将 Session 存放 在 指定 的 SQL Server 服务 器 上 。 

。 mode 二 "StateServer" 一 一 表示 将 Session 存放 在 独立 的 状态 服务 器 中 。 

注意 : 在 实际 的 工程 项 目 中 ,常常 选用 InProc 或 者 StateServer, 而 大 型 的 应 用 系统 则 
常常 选用 SQL Server, 采 用 专门 的 数据 库 来 存储 Session 信息 。 另 外 ,只 有 在 mode 为 
InProc 时 , 才 支 持 Session End 事件 。 

2) stateConnectionString 与 sqlConnectionString 

当 Sesssion 的 mode 设置 为 StateServer 时 ,需要 用 stateConnectionString 指明 连接 的 
状态 服务 器 的 连接 字符 串 , 这 个 字符 串通 常 以 "TepIp=server:port ”格式 描述 。 

当 Sesssion 的 mode 设置 为 SQLServer 时 ,需要 用 sqlConnectionString 指明 连接 的 
SQL Server 服务 器 的 连接 字符 串 ,这 个 字符 串通 常 以 “Data Source 王 数据 库 名 ; Integrated 
Security 二 True;” 的 格式 描述 。 

3) cookieless 属性 

用 于 设置 是 否 使 用 cookie 存储 Sesssion。 
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如 果 取 值 为 False, 则 表示 选用 Cookies 存储 Sesssion; 如 果 取 值 为 True, 则 表示 不 采 
用 Cookies 存储 Sesssion 。 

4) timeout 

设置 Session 的 默认 生命 期 ,时 间 的 单位 为 分 钟 。 例 如 设置 “timeout 二 "120"”, 则 表示 
本 站 点 中 Session 的 生命 周期 为 120 分 钟 。 

4. 以 Web. config 设置 用 户 身份 认证 与 授权 

作为 一 个 Web 应 用 程序 ,对 访问 者 进行 限制 是 Web 应 用 程序 开发 中 经 常 要 涉及 的 内 
容 。 在 目前 Web 应 用 系统 的 开发 中 ,主要 有 两 种 形式 的 用 户 身份 认证 方式 。 其 一 是 由 开发 
者 自行 设计 用 户 数 据 表 和 角色 表 , 然 后 通过 编写 ASP.NET 代码 并 结合 Session 技术 来 实 
现 认 证 ; 其 二 是 使 用 ASP.NET 自身 提供 的 认证 方式 。 

如 果 是 选用 第 二 种 方式 , 则 需要 修改 Web. config 文档 的 二 authentication mode 二 " 认 
证 方式 "之 节 , 对 身份 认证 方式 进行 设置 。 

在 Web. config 文件 的 二 authentication mode 王 "?" 之 节 , 共 有 以 下 4 种 模式 可 供 设置 。 
不 使 用 Web. config 执行 身份 验证 。 

Windows 一 一 采用 Windows 进行 身份 验证 。 由 Web 服务 器 (JIS 服务器) 根据 应 用 
程序 和 IIS 的 配置 来 执行 身份 验证 。 

Forms 一 一 为 用 户 提供 一 个 能 够 输入 验证 凭据 的 自 定义 窗 体 ,然后 在 应 用 程序 中 验 
证 用 户 的 身份 ; 通过 验证 的 用 户 的 凭据 标记 被 记录 在 本 地 的 Cookies 中 。 
Passport 一 一 利用 Microsoft 提供 的 Passport Web Service 进行 身份 验证 。 

对 于 身份 验证 的 问题 ,在 第 10 章 “ 登 录 模 块 设计 ”中 ,还 会 进行 比较 详细 的 探讨 。 

5, 设置 数据 库 连接 字符 串 信息 

大 型 的 动态 网 站 离 不 开 后 台数 据 库 的 支持 ,而 连接 数据 库 离 不 开 连 接 字符 串 ,因为 数据 
库 的 连接 必须 通过 连接 字符 串 提供 数据 库 的 服务 器 名 称 ,数据库 名 称 以 及 数据 库 访 问 验 证 
等 信息 。 在 具体 的 Web 应 用 系统 开发 中 ,如 果 把 连接 字符 串 直接 嵌入 到 C# 代 码 中 ,会 导 
致 编译 后 的 应 用 系统 只 能 访问 固定 名 称 的 SQL Server 服务 器 , 即 每 次 更 换 Web 服务 器 ,都 
需要 重新 编译 整个 Web 应 用 程序 ,是 不 利于 应 用 系统 迁移 的 。 

为 此 ,VS2008 提供 了 一 种 机 制 , 把 数据 库 的 连接 字符 串 书写 在 Web. config 文档 中 ,在 
应 用 程序 的 C# 代 码 中 只 说 明 连 接 字 符 串 的 名 称 。 在 这 种 方式 下 , 当 更 换 Web 服务 器 时 ， 
不 须 重新 编译 Web 应 用 系统 ,而 是 直接 修改 数据 库 连 接 字 符 串 的 内 容 即 可 。 

本 书 中 多 次 使 用 的 学 生 信 息 管理 数据 库 (XSGL) 的 连接 字符 串 如 图 9-14 所 示 ,字符 串 
的 名 称 为 “XSGLConnectionString”\ 位 于 “add name” 标 记 后 面 , 随 之 出 现 的 connectionString 
的 内 容 就 是 连接 字符 串 的 具体 内 容 。 本 例 表示 访问 本 地 服务 器 上 的 名 字 为 “sqlexpress” 的 
SQL Server 2005 服务 器 ,被 访问 的 数据 库 名 称 为 XSGL, 采 用 “Winodws 信任 ”方式 进行 访问 。 


2 机 | Conmectionstringsy 


。 none 


23 《add name="XSGLConmection3tring” 

24 cormectionString="Data Source=, \SQLExpress: Initial Catalog=XSGL;Integrated Security=True"” 
25 providerName="System. J)ata. SqlC1ient”7> 

26 《add name="TestCornection3tring" 

27 connectionString="Data Source=.\SQLExpress:;Initial Catalog=Test;Integrated Security=True" 
28: providerName=" System. Jata. SqlClient" /> 

29 /cormectionStrings> 


图 9-14 Web. config 中 有 关 connectionString 的 节 
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在 具体 开发 中 ,可 根据 需要 添加 多 个 连接 字符 串 。 但 在 实际 的 Web 应 用 系统 中 ,应 该 
尽量 把 所 有 的 数据 需求 交 给 一 个 数据 库 负责 ,减少 连接 字符 串 的 数量 ,从 而 降低 程序 的 运行 
风险 和 运行 成 本 。 

6. 设置 成 员 资格 管理 标准 

为 提高 Web 应 用 系统 的 开发 效率 ,VS2008 内 置 了 一 套 应 用 系统 的 访问 控制 机 制 ,允许 
开发 者 在 几乎 不 需要 编写 任何 代码 的 情况 下 完成 应 用 系统 登录 模块 的 开发 ,实施 “依照 用 户 
所 属 角色 (权限 ) 控 制 用 户 运行 ”的 目标 。 对 这 一 问题 的 相关 内 容 , 可 参阅 本 书 10. 2 节 。 

为 实现 对 成 员 及 其 资格 的 管理 , 须 对 成 员 名 称 ( 用 户 名 ) 成员 密码 的 设置 进行 约束 ， 
保证 每 个 成 员 的 用 户 名 和 密码 符合 一 定 的 标准 ,可 以 在 Web. config 文档 中 组 织 
过 membership 之 节 , 对 成 员 资格 的 管理 标准 进行 设置 。 

注意 ; <membership 之 节 仅 用 于 限定 成 员 资格 管理 标准 , 即 约 束 用 户 名 和 密码 的 最 短 
长 度 、 密 码 的 组 成 方式 等 。 至 于 具体 的 用 户 名 、 密 码 内 容 等 信息 , 则 存储 于 项 目的 后 台数 据 
库 ASPNETDB 中 。 

如 果 Web. config 中 没有 一 membership 之 节 ,系统 会 自动 从 Machine. config 文档 中 继承 
内 容 , 开 发 者 也 可 以 从 machine. config 文档 直接 把 相关 内 容 复 制 到 当前 项 目的 Web. config 中 。 


9.4.2 Global.asax 文档 


Global, asax 文档 (也 称 为 ASP.NET 应 用 程序 文档 ) 位 于 应 用 程序 的 根 目录 下 ,主要 用 
于 响应 ASP.NET 应 用 程序 级 别 事件 的 代码 。Global. asax 文件 是 可 选 的 ,如 果 不 定义 该 
文件 ,ASP.NET 页 框架 假设 未 定义 任何 应 用 程序 或 会 话 事件 处 理 程序 。 

1, 创建 Global. asax 文档 

在 VS2008 下 ,可 以 直接 利用 VS2008 开发 工具 的 内 置 功能 快速 创建 Global. asax 
文档 ,形成 Global. asax 文档 的 框架 ,以 便 开发 者 在 此 框架 下 编写 对 应 的 代码 。 具 体 方 
法 是 ， 

在 一 个 打开 的 ASP.NET 的 应 用 程序 下 , 右 击 【解决 方案 资源 管理 器 面板 中 的 项 目 名 
称 ,选择 [添加 】>【 新 建 项 ,然后 选择 [全 局 应 用 程序 类 ]】 ,不 要 改变 默认 的 文件 名 ,直接 添加 
即 可 创建 一 个 Global. asax 文档 ,并 自动 建立 代码 隐藏 页 Global. asax. cs 文件。 

注意 : 如 果 当 前 项 目 中 已 经 有 了 Global. asax 文件 , 则 在 项 目的 【添加 】>【 新 建 项 时 找 
不 到 【全 局 应 用 程序 类 】 栏 目 , 不 允许 重复 添加 Glabal. asax 文档 。 

2. Global.asax 文档 的 结构 

打开 新 建立 的 Glabal. asax 文档 ,会 发 现 其 内 容 如 图 9-15 所 示 。 

从 图 9-15 可 知 , 本 文档 由 7 个 方法 组 成 ,主要 面向 Application 和 Session 两 个 层次 。 
下 面 分 别 解释 主要 方法 (函数 ) 的 含义 和 用 途 。 

1) Application_Start 方法 

此 方法 用 于 响应 Web 应 用 程序 启动 事件 ,其 中 包含 的 代码 在 本 应 用 程序 首次 运行 时 触 
发 。 因 此 ,开发 者 可 以 把 初始 化 整个 应 用 程序 的 代码 撰写 到 此 处 。 

在 很 多 网 站 开发 中 ,开发 者 通常 把 网 站 访问 量 计数 器 的 初始 化 语句 撰写 在 这 个 方法 
ES 

本 方法 仅 在 整个 应 用 系统 重启 时 才 会 再 次 执行 。 
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11 浊 mamespace aaaWebApplicationl 

12:| 

13m public class Global : Systenm. Web.HttpApplication 

14 

15m protected void Application Start (object sender, Eventhrgs e) 
16， 

17 二 下 

18n protected void Session_Start (object sender, Eventhrgs e) 

19 { 

20 } 

21: 

22 澡 protected void Application BeginRequest (object sender，Eventargs e) 
23 

24 } 

25 

26i0 protected void Application AuthenticateRequest (object sender, Eventhrgs e) 
27 { 

28 } 

29; 

30ig protected void Application Error(object sender, Eventhrgs e) 
31 { 

32i[ . 

33: 

34 间 protected void Session_End(object sender, Eventhrgs e) 

35 { 

36| 

37; 

38 间 protected void Application_End(object sender, Eventhrgs e) 
39 { 

40ir 

1 } 

42.5 


9-15 ”Global. asax 文档 的 基本 结构 


2) Session_Start 方法 

此 方法 在 每 个 用 户 登 录 系 统 时 触发 。 每 个 用 户 在 首次 访问 此 应 用 系统 时 会 触发 此 方 
法 ,系统 会 自动 运行 包含 在 此 方法 中 的 语句 。 

因此 ,开发 者 通常 在 此 方法 中 撰写 用 户 登 录 时 需要 执行 的 关键 性 语句 。 比 如 统计 网 站 
在 线 人 数 和 设计 网 站 计数 器 时 都 需要 在 这 个 方法 中 使 用 累加 语句 。 

注意 : 如 果 登 录 系统 的 用 户 在 Session 有 效 期 中 再 次 访问 页 面 , 则 不 会 触发 此 方法 。 但 
用 户 的 每 一 次 在 Session 无 效 状 态 下 登录 都 会 触发 此 方法 。 

3) Session End 方法 

此 方法 在 每 个 用 户 的 Session 消亡 前 触发 。 在 客户 关闭 浏览 器 、 客 户 长 时 间 没 有 进行 
任何 网 页 内 的 操作 时 ,会 导致 客户 的 Session 消亡 ,此 时 系统 就 先 自动 运行 包含 于 此 方法 中 
的 语句 。 

例如 ,在 统计 网 站 在 线 人 数 的 程序 中 ,需要 在 Session 消亡 时 使 网 站 在 线 人 数 减 1 , 因 
此 ,需要 把 在 线 人 数 减 1 的 语句 放 在 Session_End 方法 之 中 。 

4) Application_End 方法 

此 方法 用 于 响应 Web 应 用 程序 关闭 事件 ,其 中 包含 的 代码 在 应 用 程序 被 彻底 关闭 前 执 
行 。 其 中 的 代码 常常 被 用 于 清理 系统 的 状态 和 环境 。 

3, Global. asax 文档 的 运行 机 制 

Global. asax 文档 属于 Web 应 用 程序 的 配置 文档 ,不 需要 专门 调用 它 。 在 应 用 程序 运 
行 过 程 中 会 根据 相关 事件 触发 Global. asax 文档 中 的 相关 方法 。 

另外 ,Global. asax 文档 发 生 改 变 , 也 会 导致 ASP.NET 页 框架 检测 到 该 文档 的 变动 ,从 
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而 激发 Web 服务 器 完成 应 用 程序 的 所 有 当前 请 求 ,将 Application_End 事件 发 送 到 任何 侦 
听 器 ,并 重新 启动 应 用 程序 域 。 即 导致 Web 服务 器 重新 启动 应 用 程序 ,关闭 所 有 浏览 器 会 
话 并 刷新 所 有 状态 信息 。 当 来 自 浏览 器 的 下 一 个 传人 请 求 到 达 时 ,ASP .NET 页 框架 将 重 
新 分 析 并 重新 编译 Global. asax 文件 ,而且 在 这 个 过 程 中 引发 Application_Start 事件 。 


9.4.3 Global.asax 与 Application ,Session 的 综合 应 用 


1. 制作 统计 网 站 访问 量 的 程序 

1) 设计 思路 

作为 记载 网 站 访问 量 的 数字 ,是 一 个 被 所 有 用 户 共享 的 数字 。 因 为 每 个 用 户 的 登录 都 会 
改变 这 个 数字 的 值 ,而 且 这 个 数字 的 值 可 以 被 所 有 用 户 看 到 。 因 此 这 是 一 个 Application 变量 。 

作为 一 个 Application 变量 ,需要 在 应 用 程序 启动 时 被 创建 ,赋予 初 值 0。 因此 此 变量 
在 Application_Start 时 被 创建 并 初始 化 。 

在 每 个 用 户 登录 的 时 候 ,都 需要 修改 计数 器 的 值 。 即 在 每 个 用 户 登 录 系 统 、 创 建 会 话 的 
时 候 就 要 修改 此 计数 器 的 值 ,使 之 累加 。 因 此 ,在 Session_Start 时 需要 封锁 Application 变 
量 ,修改 此 变量 的 值 。 当 然 ,修改 完毕 ,要 立即 解除 封锁 。 

最 后 ,在 应 用 程序 的 首 个 Web 窗 体 中 增加 一 个 控件 ,用 于 显示 总 访问 量 计数 器 的 值 。 

2) 设计 过 程 

在 当前 项 目的 Web 窗 体 中 新 建 一 个 Label 控件 ,修改 其 ID 为 lblCounter。 

为 当前 项 目 选择 【添加 】-“【 新 建 项 ,选择 【全 局 应 用 程序 类 后 系统 将 自动 创建 
Global. asax 文档 ,并 处 于 编辑 状态 。 修 改 Global. asax. cs 的 内 容 为 如 图 9-16 所 示 。 


11 浊 namespace WebStat 
12 


13 池 public class Global : Systenm, Web.HttpApplication 

14i { 

15 扫 protected void Application_Start (object sender, Eventhrgs e) 

16 

17 引 Application["Counter"] = 0; /定义 并 初始 化 如 plication 量 Counter 
18ir } 

19 和 和 protected void Session_Start 的 sender, Eventhrg 

20 有 

21 Application. Lock() ; /归侨 从 tpplicatI ou 

22: Application["Counter"] = (int)Application["Counter"] + 1; // 变 旦 累加 


Application UnLock€) ; // 变 量 累 加 毕 ， 和 解锁 &pplication 变 量 
} 
protected void Application BeginRequest (object sender, Eventhrgs e) 


} 


protected void Application_AuthenticateRequest (object sender, EventAres e) 


} 


protected void Application Error(object sender, Eventhrgs e) 


} 
protected void Session End(object sender, Eventhres e) 
{ 


} 


protected void Application End(object sender, Eventhres e) 


图 9-16 以 Global. asax 设计 统计 网 站 访问 量 的 代码 
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最 后 ,把 Application[ "Counter"] 的 值 赋予 lblCouter 控件 ,使 之 显示 在 当前 Web 窗 体 
中 。 因 此 需要 在 当前 窗 体 的 cs 文档 中 ,为 Page_Load 方法 添加 以 下 语句 : 

lblCounter. Text = String.Format(" 您 是 第 {0} 位 访问 者 ,欢迎 您 的 光临 !"， 

Application[ "Counter"]); 

3) 补充 说 明 

由 于 本 程序 把 访问 量 的 值 存放 在 内 存 变 量 Counter 中 ,所 以 每 次 重新 启动 本 网 站 ,都 会 
导致 网 站 访问 量 计数 器 归 0。 如 果 需 要 永久 地 保存 网 站 访问 总 量 的 值 ,可 以 考虑 把 
Appication[ "Counter"] 的 值 存放 到 数据 库 或 服务 器 上 的 文本 文件 中 。 

2. 制作 统计 网 站 在 线 人 数 的 程序 

1) 设计 思路 

作为 存储 在 线 人 数 的 数字 ,也 应 该 是 一 个 被 所 有 用 户 共享 的 变量 ,每 个 用 户 的 登录 或 者 
其 会 话 的 结束 都 会 改变 这 个 数字 的 值 。 因 此 它 必须 是 一 个 Application 型 的 变量 。 

作为 一 个 Application 变量 ,应 该 在 应 用 程序 启动 时 被 创建 ,赋予 初 值 0。 因 此 此 变量 
在 Application_Start 时 被 创建 并 初始 化 。 

在 每 个 用 户 登 录 的 时 候 需 要 对 此 计数 器 累加 ,而 在 用 户 会 话 结束 时 需要 使 此 计数 器 递 
减 。 因 此 ,在 Session_Start 时 需要 封锁 Application 变量 并 使 其 值 加 1 ,修改 完毕 要 立即 解 
除 封锁 。 同 理 , 在 Session_End 时 则 需要 在 封锁 Application 变量 的 情况 下 使 此 变量 的 值 
减 1。 

最 后 ,在 应 用 程序 的 首 个 Web 窗 体 中 增加 一 个 控件 ,用 于 显示 在 线 人 数 变 量 的 值 。 

2) 设计 过 程 

在 当前 项 目的 Web 窗 体 中 新 建 一 个 Label 控件 ,修改 其 ID 为 IblZxNum。 

为 当前 项 目 选 择 【 添 加 】>【 新 建 项 】,， 选择 【全 局 应 用 程序 类 】 后 系统 将 自动 创建 
Global. asax 文档 ,并 处 于 编辑 状态 。 修 改 Global. asax. cs 的 内 容 为 如 图 9-17 所 示 。 

最 后 ,要 把 Application[ "onLineNum"] 的 值 赋予 lblZxNum 控件 ,使 之 显示 在 当前 
Web 窗 体 中 。 因 此 需要 在 当前 窗 体 的 cs 文档 的 中 ,为 Page_Load 方法 添加 语句 : 


2ZxNum. Text = String. Format(" 目 前 共有 {0} 人 在 线 !", Application["onLineNum"]); 


3) 补充 说 明 

由 于 一 个 Web 应 用 程序 只 允许 有 一 个 Global. asax 文档 。 因 此 ,如 果菜 网 站 既 需要 统 
计 在 线 人 数 ,又 需要 统计 网 站 的 总 访问 量 , 则 可 以 把 统计 访问 量 和 统计 在 线 人 数 的 程序 拼合 
在 一 起 ,使 之 在 一 个 Global. asax 文档 中 并 存 。 

在 统计 在 线 人 数 的 过 程 中 ,屏幕 显示 的 人 数 可 能 存在 误差 。 主 要 由 两 种 因素 引起 
其 一 ,当前 用 户 获得 的 在 线 人 数 数据 是 登录 时 刻 的 统计 数据 , 当 用 户 在 本 站 点 停留 一 段 
时 间 后 ,如 果 不 刷新 页 面 ,那么 在 这 段 时 间 内 发 生 的 登录 与 注销 操作 并 不 能 自动 地 反馈 
到 用 户 的 页 面 上 ; 其 二 , 某 些 用 户 的 离线 并 没有 使 用 正规 的 注销 方式 ,不 会 立即 触发 
Session_End 事件 ,需要 等 候 一 段 时 间 , 等 这 类 用 户 的 Session 消亡 时 才能 触发 在 线 计数 器 
的 递减 操作 。 
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11 浊 mamespace WebStat 

12: 

13 浊 public class Global : Syst em.Web. Httpapplication 

14， { 

15 protected void Application_Start (object sender, EventArgs e) 

16: 

17 Application["onLineNum"] = 0; ”// 定 义 并 初始 化 邵 plication 变量 onLineNum 
18iF 

19 扩 protected void Session_Start (object de Eventhrgs e) 

20 { /f 用 户 开始 登录 时 要 修改 onLineNun 的 值 

219 Application. Lock() ; 人 /时 时 半 关 于 二 oi 9or 站 

22: Application[" onLineNum"] = (int)Application[" onLineNum"] + 1; /变量 累加 
23 Application, UnLock () ; 1/ 变价 累 加 毕 ， 解 锁 Application 变 量 

24 

25 折 protected void Application BeginRequest (object sender, EventAhrgs e) 

26 { 

27: 

28 搬 protected void Application AuthenticateRequest (object sender, Eventhrgs e) 
29 { 

30 半 

31 搬 protected void Application_Error (object sender, Eventhrgs e) 

32 { 

33 

34 和 和 protected void Session End(object sender, Eventhrgs e) 

35: { /1 用 户 注 销 时 要 修改 Counter 的 值 

36! Application. Lock() ; // 登 录 者 先 封 祸 Application 变 量 _ 
3 application["onLineNun"] = (int)Application["onLineNum"] - 1; /变星 递减 
388 Application, UnLock () ; // 变 便 递 研 毕 ， 解 锁 Application 变 量 

39 下 

40: protected void Application End(object sender, Eventhres e) 

dl { 

42 引 

43 } 

447} 


9-17 以 Global. asax 统计 在 线 人 数 的 代码 
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一 个 Web 应 用 程序 通常 由 若干 个 Web 窗 体 (页 面 ) 构 成 。 在 这 些 窗 体 为 完成 一 个 共同 
的 项 目 而 协同 工作 时 ,网 页 的 切换 与 网 页 间 的 数据 传递 是 Web 应 用 系统 开发 中 必须 统筹 思 
考 的 问题 。 


9.5.1 网 页 切换 方法 


1. 主流 的 网 页 切换 方法 

常用 的 网 页 切换 主要 有 以 下 几 种 方法 。 

(1) 利用 HTML 文档 的 超 链接 实现 切换 

在 HTML 文档 中 ,可 以 为 文字 或 图 片 添加 超 链接 。 在 访问 者 浏览 网 页 时 可 通过 单 击 
超 链 接 实现 网 页 切换 。 例 如 : 


<a href = "Url" target = "显示 网 页 的 目标 框架 "> 提示 性 文字 </a> 


(2) 利用 Web 窗 体 控件 HyperLink 实现 切换 

在 Web 窗 体 中 ,从 [工具 箱 ] 的 [标准 ] 栏 目 中 把 HyperLink 控件 添加 到 窗 体 的 适当 位 
置 , 并 为 此 控件 设置 有 效 的 Text 属性 和 NavigateUrl 属性 ,实现 Web 窗 体 类 型 的 超 链接 。 
例如 : 
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<asp:HyperLink ID = "HyperLink1”runat = "server" 

NavigateUrl = "http://www. bnu. edu. cn"> 北 京师 范 大 学 </asp:HyperLink> 

(3) 利用 客户 端 脚本 实现 切换 

针对 某 个 Web 控件 (如 按钮 ) ,为 其 onClientClick 属性 添加 JavaScript 代码 “window. 
open(Url, 样 式 信息 );” 从 而 实现 切换 到 另外 的 页 面 。 例 如 : 

<asp:Button ID = "Buttonl" runat = "server" 

onclientclick = "window. open( 'http://www. bnu. edu. cn', "')"” Text = "北京 师范 大 学 " /> 

(4) 利用 Response. Redirect(Url) 实 现 切 换 

在 Web 应 用 程序 的 逻辑 代码 设计 状态 ,可 以 使 用 语句 “Response. Redirect(Url) ;” 切 换 
到 指定 的 网 页 。 例 如 ， 

if(id == 5) Response. Redirect("jsfs.aspx"); 

表示 如 果 id 的 值 等 于 5, 就 切换 到 网 页 jsfs. aspx. 

(5) 使 用 Server. Transfer(Url) 方 法 实现 切换 

在 Web 应 用 程序 的 逻辑 代码 编辑 状态 ,可 以 使 用 语句 “Server. Transfer(Url);” 切 换 到 
指定 的 网 页 。 

在 网 站 程序 运行 过 程 中 ,系统 如 果 遇 到 了 Server. Transfer(Url) 指 令 , 则 停止 执行 当前 
网 页 ,切换 到 新 网 页 中 ,新 网 页 执行 完毕 不 再 返回 到 原 网 页 中 。 例 如 ， 


if(id== 5) Server. Transfer. ("jsfs.aspx"); 


表示 如 果 id 的 值 等 于 5, 就 切换 到 网 页 jsfs. aspx。 

(6) 使 用 Server. Execute(Url) 方 法 实现 切换 

此 命令 的 用 法 与 Server. Transfer 相似 。 

在 应 用 系统 运行 过 程 中 , 若 系统 遇 到 了 Server. Execute(Url) 指 令 , 则 停止 执行 当前 网 
页 ,切换 到 新 网 页 中 ,但 在 新 网 页 执行 完毕 还 会 返回 到 原 网 页 中 。 

2. 网 页 切换 技术 比较 

对 比 以 上 网 页 切换 技术 ,主要 有 以 下 规则 。 

方法 (1) 是 纯 HTML 文档 采用 的 方法 ,在 Web 窗 体 中 仍然 可 以 应 用 。 方 法 (2) 方 
法 (3) 则 属于 在 Web 窗 体 的 [设计 了 视图 使 用 的 方法 ,其 中 ,方法 (3) 可 以 通过 样式 指定 浏览 
器 窗口 的 形态 ,在 一 些 要求 特 效 的 站 点 中 用 得 较 多 。 

@ 方法 (4) .方法 (5) .方法 (6) 都 是 在 代码 隐藏 类 中 通过 编写 代码 实施 网 页 切换 ,属于 
C# 代 码 的 范畴 。 

@ Response. Redirect( Url) 中 的 目的 Url 并 不 局 限于 网 页 ,也 可 以 是 其 他 类 型 的 文 
件 。 对 于 浏览 器 不 能 解析 的 文件 , 则 给 予 提示 ,请 用 户 选 择 是 “保存 "还 是 “打开 ”。 而 
Server. Transfer( Url) 和 Server. Execute(Url) 中 的 Url 必须 是 同一 个 应 用 程序 中 的 aspx 
文档 。 

@ Response. Redirect(Url) 命 令 的 网 页 切换 工作 发 生 在 客户 端 ,在 切换 到 目的 网 页 后 ， 
会 在 浏览 器 的 地 址 栏 显示 出 新 网 页 的 Url 信息 ,而 且 在 退出 新 的 网 页 后 ,不 会 自动 返回 到 
原来 的 网 页 中 。 而 Server. Execute(Url) 和 Server. Transfer(Url) 命令 是 一 种 真正 的 调 
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用 。 网 页 切换 动作 发 生 在 服务 器 端 ,在 切换 到 新 网 页 后 ,浏览 器 的 地 址 栏 仍 显示 原来 
网 页 的 Url。 人 Server. Execute(UrD 实现 的 切换 中 ,如 果 退 出 新 网 页 ,系统 会 返 
回 到 原来 的 页 

© Server. -en Response. Redirect( Url) 都 可 以 在 切换 网 页 时 携带 参数 ， 
但 Response. Redirect(Url) 只 能 携带 小 于 2KB 的 参数 数据 ,而 Server. Transfer(Url) 可 以 


传递 更 大 的 参数 数据 块 。 
3. 网 页 切换 技术 的 示例 
(1) 案例 要 求 
下 面 将 提供 7 种 方法 实现 网 页 切换 ,采用 的 技术 和 界面 如 图 9-18 所 示 。 
本 程序 将 失 炼 使 用 各 种 方法 实现 页 面 切换 ， i 
a 


I 


使 用 HTML 按 钮 +JavaScript 访 问 北京 师范 大 学 。 
使 用 Web 控 件 按钮 +JavaScript 链 接 到 北京 师范 大 学 。 [北京 师范 大 学 
使 用 Web 控 件 按钮 +Rediect 链 接 到 北京 师范 大 学 。 
使 用 Web 控 件 按钮 +HTransfer 访 问 内 部 网 页 Requestaspx。| 内 部 问 页 Request 
使 用 Web 控 件 按钮 +Execute 访 问 内 部 网 页 Reqbestaspx。[ .内 部 同 页 Request 


9-18 集中 展示 网 页 切换 技术 的 界面 效果 图 


(2) 实施 功能 所 用 的 代码 
为 实现 图 9-18 所 示 的 功能 ,对 应 的 WebChange. aspx 文档 的 代码 如 图 9-19 所 示 。 


多 > 本 程序 将 币 炼 使 用 各 种 方法 实现 页 面 切换 : 《</p> 
B 
B 


form id="forml" rumat="server">Cdiv> 
0 使 用 HTIL 的 &lt ;站 gt :符号 链接 到 北京 师范 大 学 。 大 
1 《a href="http://www. bnu. edu. cn”target= blaxk) 北 京师 范 大 学 《a><br /> 


使 用 HTIL+JavaScript 访 问 北京 师范 大 学 。 hnbsp;&nbsp;&nbspi&rbspi&rnbs 
《a href="#" onclick="window. open( http;//wny, bnu. educn ， "2 北京 师 范 大 学 /akbr /> 


使 用 HTICL 按钮 +JavaScript 访 问 北京 师范 大 学 。 


《input id="Button1”type="button”value=" 北 京师 范 大 学 
onclick="window. open( http:// wy. bnu. edu. cn',' ')"/ br /> 


使 用 Web 控 件 按钮 +JavaScript 链 接 到 北京 师范 大 学 。 
《asp:Button ID="Button2”runat="server” 好 th="143px”Text=" 北 京师 范 大 学 " 
onclientclick="window. open(' http://wwy. bnu. edu. cn','')" /br /> 


2 

3 

4 

5 

6 

了 

8 

9 

0 

1 

2 

3 

d 使 用 Web 控 件 按钮 HRedirect 链 接 到 北京 师范 大 学 。 
5 《asp:Button ID="btnRedirect" runat=" server" 

6 onclick="btnRedirect_Click”Text=" 北 京师 范 大 学 "Width="146px" /><br /> 
了 
8 
9 
0 
1 
2 
3 
d 
5 
6 


使 用 Web 控 件 按钮 HTransfer 访 问 内 部 网 页 Request， aspxo 
<asp:Button ID="btnTrans” rmat="server" 
onclick="btnTrans_Click”Text=" 内 部 网 页 Request" /><br /> 


使 用 Web 控 件 按钮 HExecute 访 问 内 部 网 页 Request. aspx。 

<asp:Button ID="btnExecute" 
runat=" server” onclick="btnExecute_Click”Text=" 内 部 网 页 Request" /><br /> 
《br /YU div> 


Vforny 


9-19 集中 展示 网 页 切换 技术 的 aspx 文件 的 代码 


由 于 后 三 种 方式 采用 C# 代 码 实现 网 页 切换 ,因此 需要 编写 WebChange. aspx. cs 的 内 
容 , 对 应 的 代码 如 图 9-20 所 示 。 
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14 浊 mamespace WebStat 
上 public partial class WebChange : System. Web.UI.Page 
| protected void Page_Load(object sender, Eventhrgs e) 

! 

void btnRedirect_Click(object sender, Eventhrgs e) 


Response. Redirect ("http:// ww. bnu. edu. cn"); 


protected void btnTrans_Click(object sender，Eventargs e) 


Server. Transfer ("Request. aspx"); // 不 能 调用 外 部 网 页 


protected void btnExecute_Click (object sender, Eventhres e) 


Server. Execute ("Request.aspx"); // 不 能 调用 外 部 网 页 


图 9-20 集中 展示 网 页 切换 技术 的 C# 代 码 
9.5.2 网 页 间 参 数 传递 技术 


在 实际 应 用 中 ,经 常 需要 把 一 个 网 页 的 数据 传递 到 另外 一 个 网 页 ,或 者 一 个 网 页 产生 的 
数据 长 久 有 效 ,可 以 供 后 续 的 其 他 网 页 使 用 。 这 就 是 网 页 间 的 参数 传递 技术 。 

在 网 页 间 传 递 参 数 的 方法 主要 有 以 下 几 种 方式 。 

1. 在 URL 中 利用 "?“ 内 庶 参 数 

如 果 上 级 页 面 在 调用 下 级 页 面 时 需要 传递 数据 给 下 级 页 面 , 则 可 以 在 使 用 网 页 切换 命 
令 时 ,在 URL 中 的 文件 名 后 面 用 “?” 携 带 需 要 传递 的 数据 。 带 有 的 参数 的 URL 通常 采用 
以 下 格式 ， 


< 网 页 文件 全 称 >?< 参 数 名 > = < 参数 值 > 


前 面 例子 中 的 “Response. Redirect("showData. aspx?id 二 5")” 就 是 一 种 典型 带 有 参数 
的 URL 形式 。 如 果 系 统 需要 携带 多 个 参数 , 则 参数 之 间 可 以 使 用 *&.” 分 隔 开 来 。 例 如 : 


Response. Redirect("lookfor. aspx?xb= 女 &age = 20"); 

对 于 利用 “?” 传 递 参 数 的 方式 ,在 下 级 程序 中 必须 有 Request QueryString[“ 参 数 名 ”] 
来 获取 参数 的 值 ,并 把 值 赋予 本 程序 内 的 内 存 变 量 中 。 例 如 ,在 showData. aspx 中 必须 包 
会 语句 

String id = Request. QueryString[ "id"]; 
从 而 把 上 级 程序 提供 的 数值 *5” 传 人 到 showData. aspx 内 部 。 同 理 ,在 lookfor. aspx 程序 
中 至 少 应 该 包含 以 下 两 个 语句 : 


String xb = Request. QueryString[ "xb" ]; 
String age = Request. QueryString[ "age" ]; 


从 而 把 上 级 程序 提供 的 查询 条 件 导 入 到 lookfor. aspx 之 中 。 


235 


4 


236 


动态 网 站 设计 与 开发 (ASP. NET 版 ) 


在 这 两 个 小 例子 中 ,需要 注意 下 级 程序 内 “[] ”中 的 参数 名 必须 与 上 级 程序 中 “?” 后 面 的 
参数 名 一 致 。 至 于 String 类 型 后 面 的 内 存 变 量 名 ,可 以 与 参数 名 相同 ,也 可 以 不 同 。 

2. 利用 Session 实现 参数 传递 

在 一 个 应 用 程序 中 ,经 常 存在 某 些 变量 需要 跨 多 个 网 页 存在 ,而 且 在 一 个 会 话 周期 中 多 
次 使 用 。 例 如 信息 系统 中 的 用 户 账号 、 用 户 姓 名 和 用 户 角色 信息 。 如 果 对 这 些 变量 的 跨 页 
面 使 用 都 采用 参数 传递 ,网 页 链接 中 的 URL 将 变 得 非常 复杂 。 

对 于 这 种 情形 ,通常 可 以 通过 定义 Session 变量 的 方法 来 解决 。 对 于 Session 变量 来 
讲 , 由 于 每 个 访问 者 都 有 自己 的 Session 实例 ,不 必 担 优 此 用 户 的 操作 对 彼 用 户 产生 影响 。 
因此 ,利用 Session 实例 能 够 跨 页 面 存在 的 属性 就 可 以 实现 大 范围 的 参数 传递 。 

由 于 一 旦 定义 了 某 个 Session 变量 ,将 会 为 每 个 登录 用 户 创建 其 实例 。 因 此 对 一 个 并 
发 量 很 大 的 网 站 来 讲 , 每 个 Session 变量 都 可 能 导致 很 大 的 服务 器 开销 。 因 此 ,在 Web 网 站 
设计 中 ,应 该 尽量 减少 Session 的 定义 。 

3. 通过 数据 库 或 中 间 文 件 传递 数据 

如 果 网 页 间 需 要 传递 的 数据 规模 非常 大 ,难以 采用 URL 携带 参数 方式 或 Session 方式 
传递 , 则 可 以 另辟蹊径 。 

提供 数据 的 前 级 程序 可 以 创建 一 个 临时 文档 ,把 需要 传递 的 数据 存储 到 这 个 临时 文档 
中 。 作 为 接收 方 的 后 继 程序 则 可 以 直接 从 这 个 临时 文档 中 读 取 数 据 。 这 是 以 临时 文件 作为 
中 介 实 施 网 页 间 数 据 传 输 的 模式 。 

当然 ,也 可 选用 数据 库 作 为 中 介 ,实现 不 同 网 页 之 间 的 数据 传递 。 

4. 对 网 页 参数 的 编码 处 理 

在 以 *?" 携 带 参数 实现 网 页 间 数 据 传递 的 技术 中 ,如 果 参 数 中 的 字符 串 比较 复杂 ,甚至 
其 中 含有 能 够 引起 歧义 的 *“&” 和 “?” 时 ,就 会 导致 接受 方 无 法 获取 到 正确 的 数据 。 例 如 ,要 
在 参数 中 传递 两 个 人 名 : 李 萍 和 王 丽 。 如 果 书 写 为 如 下 的 格式 ， 


showData. aspx?xm = 李 萍 & 王 丽 


必然 导致 接受 错误 ,丢失 “ 王 丽 ” 二 字 。 因 为 系统 把 “ 李 萍 & 王 丽 ? 之 间 的 “& ”解析 成 了 参数 
分 隔 符 。 

为 了 保证 参数 传递 的 正确 性 ,建议 首先 对 参数 采取 特定 的 编码 处 理 , 再 作为 参数 值 传 
输 ,而 接受 方 则 需要 先 解码 再 使 用 。 

例如 ,要 在 新 闻 信息 系统 中 查询 指定 标题 的 消息 ,消息 的 标题 由 文本 框 txt 提供 ,如 果 
以 参数 传递 的 方式 把 要 查找 的 标题 传递 给 显示 程序 showNews. aspx, 那 么 可 以 这 样 书写 调 
用 语句 ， 


Response. Redirect("showNews.aspx?id = " + Server. UrlEncode(txt. Text. Trim())); 


表示 在 获取 文本 框 txt 的 输入 内 容 后 先进 行 去 空格 处 理 ,然后 再 按照 UrlEncode 规范 
实施 编码 ,把 编码 结果 作为 参数 值 放 在 “id=? 的 后 面 。 由 于 上 级 程序 对 网 页 参数 值 进行 了 
编码 处 理 , 那 么 在 showNews. aspx 中 提取 参数 值 时 就 必须 进行 解码 处 理 ,可 以 采用 下 面 的 
语句 : 


String id = Server. UrlDecode(Request. QueryString[ "id" ]); 
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正 是 由 于 采取 了 这 种 编码 处 理 ,避免 了 新 闻 标题 中 的 特殊 字符 引发 歧义 ,保证 了 数据 的 
正确 传递 。 

如 果 需 要 对 网 页 内 容 编码 处 理 , 则 可 以 使 用 “Server. HtmlEncode( 字 符 串 变量 名 )” 和 
“Server. HtmlDecode( 字 符 串 变量 名 ) ”实施 编码 与 解码 。 


9.5.3 网 页 间 参 数 传递 示例 


已 知 在 当前 应 用 中 ,存在 两 个 Web 窗 体 文件 DataZongin. aspx 和 DataZongRes. aspx。 
如 图 9-21 和 图 9-22 所 示 。 和 希望 当 在 DataZongin. aspx 的 文本 框 中 输入 姓名 和 性 别 后 ,将 会 
在 DataZongRes. aspx 窗 体 中 显示 出 对 应 信息 。 如 果 在 DataZongin. aspx 中 输入 的 姓名 为 
“ 张 三 ”, 性 别 为 *“ 女 ”, 则 在 DataZongRes. aspx 窗 体 显示 “您 好 ,欢迎 张 三 小 姐 光 临 1”; 如 果 
在 DataZongin. aspx 输 入 姓名 * 张 三 ”性 别 “ 男 ”, 则 在 DataZongRes. aspx 窗 体 显示 “您 好 ， 
欢迎 张 三 先 生 光 临 1”。 

这 是 一 个 典型 的 在 网 页 间 实 现 数据 传递 的 题目 。 下面 将 采用 不 同 的 技术 实现 数据 
传递 。 

1. URL 内 赔 参 数 的 模式 一 一 参数 值 无 编码 方式 

1) 案例 要 求 

设计 如 图 9-21 和 图 9-22 所 示 的 两 个 窗 体 程序 DataZongin. aspx 和 DataZongres 
.aspx, 其 中 DataZongin. aspx 作为 调用 DataZongres. aspx 的 前 级 程序 。 分 别 用 4 个 按钮 体 
现在 URL 中 携带 参数 进行 数据 传递 的 模式 。 说 明 ; 图 9-21 中 两 个 文本 框 的 ID 分 别 是 
txtXm 和 txtXb, 分 别 用 于 输入 姓名 和 性 别 信息 。 


您 好 欢迎 马 秀 脑 先生 光临 ! 


请 您 输入 ， 
您 的 姓名 ， 马 表明 
您 的 性 别 ， ”更 


[aa 
| 用 Execute 传 递 天 于 JavaScript 传 递 | 


9-21 DataZongin 效果 图 图 9-22 ”DataZongres 效果 图 


2) 实现 图 示 功 能 所 需 的 代码 

(1) 前 级 程序 4 个 按钮 的 Click 事件 的 响应 代码 如 图 9-23 所 示 。 

(2) 接受 程序 通过 Request. QueryString 语句 获取 URL 参数 的 值 。 为 保证 读 取 的 正 
确 性 和 系统 效率 ,本 程序 把 接收 数据 语句 放 在 了 页 面 的 Page_Load 阶段 。 对 应 的 代码 如 
图 9-24 所 示 。 

2. URL 内 嵌 参 数 的 模式 一 一 参数 值 编码 方式 

为 保证 参数 值 的 正确 性 与 完整 性 ,通常 需要 在 前 级 程序 中 使 用 URL 编码 模式 对 参数 
值 进 行 编码 。 在 前 级 程序 中 ,为 响应 网 页 切换 按钮 (BtnCode) 的 Click 事件 而 编制 的 代码 如 
图 9-25 所 示 。 

接受 程序 按照 解码 方式 接收 数据 , 即 接收 数据 后 立即 解码 ,然后 再 存储 到 相应 的 内 存 变 
量 中 。 对 应 的 代码 如 图 9-26 所 示 。 
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22 protected void btnRedirect_Click (object sender, Eventhres e) 


String xm = txtXm. Text. Trim() ; // 获 取 姓 名 信息 ， 并 去 掉 多 余 空格 

String xb = txtXb. Text. Trim() ; // 获 取 性 别 信 息 ， 并 去 掉 多 余 空 格 

String url=String. Format ("DatalongRes. aspx ?xn= {0} &xb={1 1" ,xm xb) ; 
AZ 借助 字符 加 格式 化 方式 ， 构 造 URL 字 符 串 

Response. Redirect fur1) : 


31im protected void btnTranfer_Click(object sender，Eventargs e) 


String xm = txtXm. Text. Trim(); 

String xb = txtXb. Text. Trinm(); 

String url = String.Format ("DataZongRes. aspx?xm= {0}&xb= {1}", xm, xb); 
Server. Transfer (url) ; 


protected void btnExecute Click(object sender, Eventhrgs e) 
{ 


45 上 | 1} 


String xm = txtXn. Text. Trim(); 

String xb = txtXb, Text. Trinm(); 

String url = String.Format ("Data7ongRes. aspx ?xm= {0}&xb= {1}", xm, xb):; 
Server. Execute (url) ; 


protected void btnJS_Click (object sender, EventArgs e) 


String xm = txtXm, Text. Trim(); 

String xb = txtXb. Text. Trim() ; 

String url = String.Fornmat ("DataZongRes. aspx ?xm= {0} &xb= {1}", xm, xb):; 
Response. Write ("Script >window, open(’" Hurl+"',' ') /Script>"):; 


图 9-23 实施 网 页 切换 的 前 级 程序 (调用 者 ) 


protected void Page_Load(object sender, Eventhrgs e) 


String xn=Request,. QueryString["xm"]; 

String xb = Request. QueryString ["xb"] ; 

证 (xb == " 女 ") lblInfo. Text = "您 好 ,欢迎 ”+ xn + "小 姐 光 临 !"; 
else 1blInfo, Text =“" 您 好 ,欢迎 ”+ xm + "先生 光临 !"; 


图 9-24 实施 网 页 切换 的 后 级 程序 (被 调用 者 ) 


23 
24 
25 
26 
27 
28 
29 
30i 


protected void btnCode_C1ick (object sender，Eventargs e) 


String xm =Server, UrlEncode (txtXm. Text. Trim()); // 获 取 姓 名 信息 并 编码 
String xb =Server. UrlEncode (txtXb. Text, Trin()); // 获 取 性 别 信 息 并 编码 
String url = String.Fornat ("DataCodeRes. aspx?xn= {0}&xb={1}", xn, xb) ; 
/借助 字符 帅 格 式 化 方式 ， 构 造 URL 字 符 串 


Response. Redirect (url) ; 


图 9-25 采用 URL 参数 编码 模式 的 网 页 切换 的 前 级 程序 (调用 者 ) 


protected void Page Load(object sender, Eventhrgs e) 
{ 


String xm =Server. UrlDecode (Request. QueryString["xm"]); 
/1 获取 参数 值 并 和 解码 
String xb = Server. UrlDecode (Request. QueryString["xb"]); 
/获取 参数 值 并 解码 
证 (xb == " 女 ") lblInfo.Text = "您 好 ,欢迎 " + xm + "小 姐 光 临 ! ": 
else lblInfo.Text = "您 好 ,欢迎 ”+ xn + "先生 光临 !"; 


图 9-26 采用 URL 参数 编码 模式 的 网 页 切换 的 后 级 程序 (被 调用 者 ) 


第 9 章 ”应 用 程序 配置 与 网 页 切换 


3. 基于 Session 的 参数 传递 模式 
使 用 Session 实施 数据 在 网 页 间 传 递 是 一 种 比较 简单 的 方式 ,而 且 可 以 跨 多 个 页 面 存 
在 。 创 建 Sesssion 变量 的 代码 如 图 9-27 所 示 。 


protected void btnSession Click(object sender，EventArgs e) 
{ 


String xm = txtXm, Text. Trim() ; // 获 取 姓 名 信息 并 去 除 空格 
String xb = txtXb. Text. Trim(); /获取 性 别 信息 并 去 除 空格 
Session["Sxm"] = xm; 。 A/ 定 义 Session 变 量 Sxnm 
Session["Sxb"] = xb; 7/ 定义 Session 变 旺 Sxb 

Response. Redirect ("DataSessionRes. aspx"); 


9-27 采用 Session 传递 参数 的 网 页 切换 的 前 级 程序 (调用 者 ) 


由 于 使 用 了 Session ,接受 程序 不 必 使 用 专门 的 语句 读 取 数据 ,而 是 可 以 像 使 用 本 地 内 
存 变量 一 样 直接 应 用 Session 的 实例 。 相 关 代 码 如 图 9-28 所 示 。 


18i protected void Page Load(object sender, EventArgs e) 
{ 


20 String xm = Session["Sxm"],ToString();  // 从 Session 实 例 中 获取 和 参数 值 xm 
21: String xb = Session[" Sxb"],. ToString (); 1/ 从 session 详 例 中 获取 参数 值 xb 
22 证 (xb ==" 女 ") lblInfo.Text = "您 好 ,欢迎 "+ xn + | 姐 光临 ! ": 

23 else lblInfo, Text = "您 好 ,欢迎 ”+ xm +“ 先 生 光临 


图 9-28 采用 Session 传递 参数 的 网 页 切换 的 后 级 程序 (被 调用 者 ) 


假 考题 


1. 如 何 获得 远程 访问 者 的 IP 地 址 ? 如 何 获得 远程 访问 者 的 浏览 器 版 本 ? 

2. 在 Web 应 用 程序 中 ,实现 网 页 切换 的 技术 主要 有 哪些 ?哪些 隶属 于 HTML 方式 ? 
哪些 属于 C# 代 码 方式 ? 

3，Response. Redirect() 切 换 有 什么 特点 ?Server. Transfer() 与 Server. Execute() 的 
切换 方式 有 什么 不 同 ? 对 目标 文件 有 什么 限制 ? 

4. 什么 是 Session 变量 和 Application 变量 ?这 两 种 变量 在 作用 域 方面 有 哪些 不 同 ? 

5. Web 应 用 程序 的 配置 文件 有 哪 两 个 ? 分 别 位 于 什么 位 置 ? 各 有 什么 作用 ? 二 者 的 
关系 是 什么 ? 

6， Web. config 以 什么 格式 保存 Web 应 用 程序 的 配置 信息 ? 主要 包括 哪些 方面 的 配置 
信息 ? 

7. Web 应 用 系统 的 数据 库 连 接 字符 串 存储 于 什么 位 置 ? 为 什么 不 直接 把 数据 库 连 接 
字符 串 写 到 C# 的 源 程序 中 ? 

8. Global. asax 文档 位 于 什么 位 置 ,有 什么 作用 ? 其 主要 结构 是 什么 ? 

9. 如 果 要 设计 一 个 统计 网 站 访问 量 的 模块 ,计数 器 变量 应 该 配置 为 什么 类 型 ? 应 该 在 
什么 位 置 初始 化 计数 器 变量 ? 应 该 在 什么 位 置 进行 计数 器 的 累加 ? 

10. URL 参数 方式 是 实现 网 页 间 数 据 传递 的 一 种 主要 形式 。 为 了 保证 传递 参数 值 的 
正确 性 与 完整 性 ,通常 对 参数 值 执行 哪些 操作 ? 


240 


Nt 


动态 网 站 设计 与 开发 (ASP. NET 版 ) 


11. 在 Web 应 用 程序 中 ,如 何 使 用 Session 变量 实现 网 页 间 的 参数 传递 ? 
12. 在 Web 应 用 程序 中 ,被 调用 程序 如 何 获 取 前 级 程序 以 URL 参数 模式 传递 过 来 的 
参数 值 ? 


仁 机 实 训 是 


新 建 项 目 TEST9 ,在 此 项 目 中 实现 以 下 功能 。 

(1) 新 建 窗 体 ClientInfo, 在 此 窗 体 中 获取 访问 者 的 IP 地址、 浏览 器 类 型 等 信息 ,并 列 
出 服务 器 变量 的 反馈 信息 。 

(2) 新 建 窗 体 Counter, 在 此 Counter 中 创建 网 站 访问 量 计数 和 在 线 人 数 计 数 功能 。 

(3) 打开 当前 项 目的 Web. config 文档 ,观察 Web. config 文档 的 内 容 、 结 构 , 并 尝试 能 
够 通过 Web. config 文档 修改 Web 应 用 程序 的 配置 信息 。 

(4) 新 建 窗 体 Al 和 A2。 首 先 ,在 Al 中 设置 TextBox 控件 和 Button 控件 ; 其 次 ,针对 
Al 窗 体 中 的 Button 控件 ,为 其 Click 事件 添加 对 应 方法 。 在 其 中 加 入 各 种 以 “URL 参数 模 
式 ” 调 用 A2 窗 体 的 语句 ; 再 次 ,在 A2 中 设置 “获取 URL 参数 值 ” 的 语句 并 输出 获得 的 数 
据 ; 最 后 ,预览 Web 窗 体 Al ,测试 网 页 间 参 数 传递 的 有 效 性 。 

(5) 新 建 窗 体 Bl 和 B2。 首 先 ,在 Bl 中 设置 TextBox 控件 和 Button 控件 ,并 为 Button 
控件 的 Click 事件 添加 方法 ,在 方法 中 完成 以 下 操作 : 把 TextBox 的 值 设置 为 Session 变 
量 ; 直接 调用 B2 窗 体 ; 其 次 ,在 B2 窗 体 中 显示 出 相应 Session 量 的 值 ; 最 后 ,预览 Web 窗 
体 B1 ,测试 网 页 间 Session 传递 数据 的 有 效 性 。 
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学 习 要 点 
本 章 主要 学 习 ASP.NET 应 用 程序 中 实现 用 户 登录 与 操作 权限 控制 的 技术 。 要 求学 习 
者 了 解 ASP.NET 技术 中 实现 登录 与 权限 控制 模块 的 基本 组 织 体系 ,了 解 实现 登录 模块 的 
两 种 方法 。 了 解 .NET 3.5 内 置 的 成 员 资格 管理 体系 的 组 成 要 素 和 组 织 方法 ,掌握 自主 开 
发 登录 模块 的 关键 技术 。 本 章 重 点 关注 以 下 内 容 : 
。 实现 登录 与 权限 控制 模块 的 主要 方法 和 思路 。 
。 内 置 的 成 员 资格 管理 体系 的 组 成 ,ASPNETDB 文件 的 结构 ,及 创建 用 户 、 创 建 角色 、 
创建 访问 规则 的 含义 。 
。 为 实现 内 置 的 成 员 资 格 管理 而 配置 关键 控件 : Login, CreateUserWizard,Change- 
Password,PasswordRecovery 等 ,为 超级 管理 员 准 备 的 Membership 类 和 Roles 类 
的 简单 使 用 。 
。 自主 开发 登录 模块 的 关键 技术 、Session 变量 的 应 用 。 
。 在 自主 开发 权限 控制 体系 中 ,对 应 用 程序 访问 者 的 控制 方法 。 


Qo, 1 Web 应 用 系统 安全 性 机 制 


在 动态 网 站 开发 中 ,为 约束 外 部 用 户 对 Web 系统 的 访问 ,需要 采取 一 定 的 安全 机 制 , 把 
非法 用 户 屏蔽 到 系统 之 外 。 从 Web 应 用 系统 安全 性 管理 的 视角 看 ,主要 可 通过 网 络 技术 、 
ASP.NET 内 置 的 认证 技术 、 自 主 开 发 认证 模块 等 技术 手段 实现 。 


10.1.1 基于 网 络 技术 的 访问 控制 机 制 


1. 以 防火 墙 . 路 由 器 隔离 Web 服务 器 

在 动态 网 站 开发 中 ,可 以 在 Web 服务 器 与 Internet 之 间 设 置 防火 墙 ,或 者 利用 路 由 器 
限制 外 部 用 户 对 服务 器 的 访问 ,甚至 可 以 采用 物理 隔离 ( 断 开 Web 服务 器 与 外 网 的 物理 连 
接 ) 方 式 把 网 站 的 用 户 约束 在 一 个 有 限 的 范围 之 内 。 

2. 通过 IP 地 址 限制 Web 服务 器 用 户 

在 Web 服务 器 中 ,存在 针对 虚拟 目录 的 IP 约束 机 制 。 开 发 者 可 以 利用 Web 服务 器 配 
置 文件 ,设置 可 以 访问 虚拟 目录 的 客户 端 IP 地址 ,把 非法 用 户 的 IP 地 址 限定 在 系统 之 外 。 

关于 Web 服务 器 的 配置 内 容 ,请 参阅 Web 服务 器 配置 的 章节 。 


242 


SAA 


动态 网 站 设计 与 开发 (ASP. NET 版 ) 


10.1.2 基于 ASP. NET 体系 的 访问 控制 机 制 


在 ASP.NET 中 ,提供 了 一 套 有 效 的 控制 机 制 对 外 部 用 户 进 行 控制 ,涉及 的 主要 技术 有 
以 下 此 个 

1. 通过 Web. config 文档 配置 访问 控制 模式 

在 Web. config 文档 中 专门 配置 了 一 个 小 节 , 用 于 对 当前 Web 应 用 系统 的 身份 认证 方 
式 进行 设置 ,这 就 是 authentication 配置 。 

在 Web. config 文件 的 二 authentication mode 王 "?" 之 节 , 共 有 4 种 模式 可 供 设置 。 
其 中 : 


表示 不 使 用 Web. config 执行 身份 验证 。 
表示 采用 Windows 系统 内 置 的 账号 进行 身份 验证 , 即 由 Web 服务 器 
(IIS 服务 器 ) 调 用 Windows 内 置 的 用 户 名 、 权 限 等 设置 来 执行 身份 验证 。 
Forms 一 一 为 用 户 提供 一 个 能 够 输入 验证 凭据 的 自 定义 窗 体 ,然后 在 应 用 程序 中 验 
证 用 户 的 身份 ; 把 通过 验证 的 用 户 凭据 记录 在 本 地 的 Cookies 或 者 Session 中 ,从 而 
实现 用 户 操作 管理 。 
Passport 一 一 利用 Microsoft 提供 的 Passport Web Service 进行 身份 验证 。 

2. 基于 Windows 实施 身份 验证 

基于 Windows 的 身份 验证 根据 Windows 服务 器 的 文件 系统 NTFS 和 Windows 的 内 
置 账户 实施 身份 验证 ,使 只 有 隶属 于 Windows 服务 器 账户 而 且 对 Web 服务 器 的 文件 夹具 
有 操作 权限 的 用 户 才 能 访问 Web 应 用 系统 。 

基于 Windows 实施 身份 验证 技术 建立 在 Windows 服务 器 账户 .NTFS 文件 系统 IIS 
的 Web 服务 器 配置 三 个 维度 的 密切 配合 。 

3. 基于 Forms 的 用 户 身份 验证 

基于 Forms 实施 用 户 身 份 验证 是 当前 信息 系统 ,动态 网 站 开发 中 用 得 最 广泛 的 方式 。 
其 基本 思路 是 : 以 窗 体 表单 接受 用 户 输 入 的 身份 信息 (如 用 户 名 、 密 码 ) ,然后 由 身份 验证 模 
块 对 用 户 输入 的 身份 信息 进行 检验 。 只 有 通过 检验 的 用 户 才 可 以 访问 Web 应 用 系统 。 


none 


Windows 


(0,2 Form 认证 机 制 的 工作 原理 


所 谓 Form 认证 (表单 认证 ) ,就 是 利用 Form 验证 用 户 身份 ,并 使 通过 验证 的 用 户 在 允 
许 的 范围 操作 。 其 中 包括 两 重 含义 : 用 户 和 用 户 在 应 用 系统 内 的 操作 范围 。 而 要 真正 地 实 
现 这 两 重 约束 , 则 需要 角色 和 访问 规则 概念 的 支持 。 


10.2.1 成 员 资 格 管理 


1. 成 员 与 角色 的 概念 

在 Web 应 用 系统 开发 中 ,成 员 (Users) 与 角色 (Roles) 的 概念 是 无 法 回避 的 知识 。 所 谓 
成 员 ,就 是 Web 应 用 系统 中 的 用 户 ,而 角色 就 是 Web 应 用 系统 中 成 员 的 类 别 。 

从 现实 世界 中 人 工 管理 的 视角 看 ,成员 就 是 组 织 机 构 内 部 的 一 个 个 的 工作 人 员 ,而 角色 
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则 是 与 成 员 密切 相关 的 职位 信息 、 人 员 类 别 的 信息 。 例 如 ,在 一 个 图 书馆 的 内 部 管理 中 , 张 
三 , 李 四 等 工作 人 员 是 具体 的 成 员 , 同 时 张 三 、 李 四 等 人 又 必须 承担 一 定 的 职责 , 即 他 们 必须 
具备 一 定 的 角色 成 分 。 在 客观 现实 中 ,管理 权限 是 赋予 角色 的 ,而 不 是 赋予 成 员 的 。 成 员 只 
有 承担 某 个 角色 ,才能 具备 相关 的 权利 。 

因此 ,在 Web 应 用 系统 开发 过 程 中 ,对 成 员 和 角色 的 设计 是 实施 表单 认证 机 制 的 首要 
任务 。 特 别 是 角色 设计 ,对 系统 的 成 败 具有 决定 性 的 作用 。 

注意 ; ASP.NET 内 置 了 一 套 成 员 资格 管理 体系 , 供 开 发 者 在 应 用 程序 开发 时 用 来 设 
计 登 录 模块 和 系统 的 访问 规则 。 

有 时 ,角色 也 被 称 为 用 户 组 (Group) ,二 者 具有 相同 的 语义 功能 和 语义 环境 。 

2. 访问 规则 

在 客观 世界 的 管理 活动 中 ,管理 权限 是 赋予 角色 的 ,每 一 角色 承担 相应 的 任务 。 每 个 角 
色 具 有 的 权限 是 约定 俗 成 或 者 是 经 批准 的 。 

同 理 , 在 Web 应 用 系统 的 设计 中 ,需要 清晰 地 设计 出 每 个 角色 的 访问 权限 ,指定 每 个 角 
色 访 问 程序 模块 的 范围 ,不 允许 角色 超出 自己 的 管理 范围 越位 操作 。 

人 们 把 限定 角色 访问 范围 的 设计 叫 访问 规则 设计 ,针对 角色 制定 的 访问 约束 条 件 被 称 
为 访问 规则 。 


10.2.2 表单 认证 机 制 的 工作 原理 


1. 实施 成 员 访问 权限 管理 的 数据 库 机 制 

由 于 任 一 Web 应 用 系统 的 成 员 都 不 是 1 个 .2 个 ,而 是 成 员 众多 ,而 且 角 色 繁多 ,为 了 
对 成 员 和 角色 实施 管理 ,建立 基于 数据 库 技术 的 成 员 表 和 角色 表 是 必 不 可 少 的 。 即 利用 数 
据 库 技术 首先 在 数据 库 内 部 创建 角色 表 , 用 于 管理 系统 的 角色 信息 ; 然后 创建 成 员 表 ,用 以 
管理 系统 内 部 的 成 员 信息 。 

由 于 成 员 具 有 的 操作 权利 需要 通过 角色 获取 ,因此 清晰 地 描述 成 员 所 具备 的 角色 是 非 
常 必 要 的 。 如 果 每 名 成 员 只 承担 一 个 角色 ,那么 只 须 在 成 员 表 中 增加 角色 字段 来 说 明成 员 
的 角色 即 可 。 如 果 允 许 一 名 成 员 承 担 多 种 角色 , 则 需要 新 建 专门 的 数据 表 * 成 员 权 限 表 "? 来 
描述 成 员 与 角色 的 关系 。 

角色 具备 的 操作 权利 由 访问 规则 决定 。 对 于 一 个 小 型 系统 来 讲 , 可 以 直接 在 程序 代码 
中 实施 访问 规则 。 只 需 通过 简单 的 代码 ,制作 出 面向 角色 的 个 性 化 菜单 ,就 可 完成 针对 角色 
的 授权 。 而 对 大 型 的 系统 来 讲 , 则 需要 在 后 台数 据 库 中 创建 访问 规则 表 , 利 用 访问 规则 对 角 
色 和 程序 模块 ,数据 表 之 间 的 控制 关系 进行 描述 。 

角色 成 员 与 程序 模块 之 间 的 关系 如 图 10-1 所 示 。 


成 员 nc 角色 |< 和 和 制 > 于 一 | 程序 模块 


图 10-1 成 员 、 角 色 、 程 序 模块 之 间 的 关系 


2. 表单 认证 机 制 的 工作 流程 
根据 表单 认证 的 特点 ,要 实施 表单 认证 机 制 ,必须 遵循 以 下 流程 。 
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(1) 事先 设计 角色 ,确定 角色 的 访问 规则 。 然 后 完成 相关 的 成 员 表 .角色 表 的 制作 。 如 
果 系 统 很 大 ,还 需要 制作 成 员 角 色 关 系 表 和 访问 规则 表 。 

(2) 为 成 员 表 、 角 色 表 等 关键 表格 输入 部 分 初始 信息 。 

(3) 制作 用 于 用 户 输入 个 人 信息 的 表单 。 

(4) 对 用 户 输入 的 个 人 信息 进行 验证 。 这 一 过 程 主要 包括 到 用 户 表 中 检查 用 户 输入 的 
用 户 名 和 密码 是 否 正确 。 对 于 正确 登录 的 合法 用 户 , 则 需要 通过 其 角色 和 访问 规则 来 确定 
用 户 的 访问 权限 。 

(5) 根据 用 户 的 访问 权限 显示 出 个 性 化 菜单 ,为 用 户 使 用 Web 系统 提供 清晰 的 、 允 许 
范围 内 的 导航 体系 。 

注意 : 在 使 用 表单 认证 机 制 进行 用 户 访问 控制 时 ,要 注意 采取 一 定 规则 加 强 用 户 身份 
的 认证 ,同时 还 要 防止 没有 通过 登录 页 面 验证 的 用 户 直 接 调用 内 部 aspx 文件 ,造成 不 应 有 
的 损失 。 

设计 表单 认证 机 制 的 关键 工作 步骤 如 图 10-2 所 示 。 


提交 。 | 验证 表单 


验证 结论 通过 
验证 


通 
过 


一 | 验证 数据 表 


数据 库 获取 角色 信息 


展示 个 性 化 菜单 


登录 模块 程序 
10-2 ”表单 认证 机 制 的 关键 工作 步 又 


10.2.3 表单 认证 机 制 的 组 成 体系 


要 真正 地 实施 一 套 完整 的 表单 认证 系统 是 非常 复杂 的 。 

从 功能 上 看 , 既 要 包含 面向 终端 用 户 的 前 台 操 作 , 还 要 包括 面向 系统 管理 员 的 用 户 管理 
机 制 。 对 终端 用 户 来 讲 , 需 要 有 系统 登录 与 验证 模块 、 修 改 密码 模块 、 密 码 重 置 模块 ,获取 角 
色 并 设置 个 性 化 菜单 模块 ; 而 对 系统 管理 来 讲 , 还 需要 包括 新 增 角色 模块 ,新 建 用 户 模块 、 
用 户 列表 模块 ,角色 列表 模块 .删除 用 户 模块 .修改 用 户 信息 模 块 、 设 置 用 户 角色 模块 ,设置 
访问 规则 模块 等 功能 。 

从 系统 的 信息 组 成 上 看 ,需要 包括 后 台数 据 库 、 上 述 功能 模块 ,而 且 还 要 包括 必要 的 配 
置信 息 。 

从 表单 认证 机 制 的 实施 看 ,其 组 成 体系 如 图 10-3 所 示 。 
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表单 认证 模块 的 功能 
用 户 数据 库 
普通 多 
用 户 表 ] 角色 表 上 | 模块 出 史 用 
| 

用 户 角 色 关 系 | | 访问 规则 | | | [ 登 |[ 修 |[ 密 |[ 获 |[ 修 | [用 [新 |[ 亚 |[ 重 ] [多 |[ 甩 ][ 访 
对 || 改 || 玛 || 到 || 改 | | 户外 增 || 除 || 辕 || 色 || 户 | 癌 
与 || 密 || 重 || 角 | 个 | | 有 || 甩 || 甩 | 再 || 得 || 角 | 规 
验 || 码 || 置 || 色 | 人 | | 表 | 户 上 户 | 上 | 户 || 吾 || 色 | 总 
证 省 密 || | | 设 

奶 码 || || 重 
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fo.3 VS2008 内 置 的 登录 体系 


为 支持 登录 与 验证 ,VS2008 内 置 了 一 套 完整 系统 ,这 套 系统 以 ASPNETDB 作为 Form 
的 认证 数据 库 , 用 于 存储 用 户 表 、 角 色 表 等 相关 信息 ,同时 以 Class 的 形式 对 为 各 功能 模块 
设计 专用 的 类 。 由 于 VS2008 的 内 置 成 员 资格 体系 非常 完整 ,开发 者 不 需 编码 就 能 完成 一 
个 Web 应 用 系统 的 访问 控制 工作 。 


10.3.1 VS2008 内 置 登录 体系 的 构件 


1. 后 台数 据 库 ASPNETDB 

以 VS2008 内 置 的 登录 体系 构造 登录 模块 ,需要 建立 在 数据 库 ASPNETDB 的 基础 上 。 
ASPNETDB 是 一 个 SQL Server 2005 数据 库 ,存储 在 项 目的 App_Data 文件 夹 下 。 

注意 : 默认 状态 下 ,VS2008 不 会 在 用 户 的 项 目 中 创建 ASPNETDB 数据 库 。 只 有 在 
Web 窗 体 中 添加 了 登录 控件 ,并 且 利 用 登录 控件 的 【管理 网 站 功能 进入 到 网 站 配置 状态 ， 
把 网 站 的 “身份 验证 方式 ”选择 为 【通过 Internet】 验 证 后 ,VS2008 才 会 自动 在 项 目的 App 
_Data 文 件 夹 中 创建 ASPNETDB 数据 库 。 

利用 [服务 器 资源 管理 器 ] 面 板 的 添加 [数据 连接 】 ,然后 按照 [附加 一 个 数据 库 文件 3 的 
方式 可 以 把 App_Data 下 的 ASPNETDB 数据 库 添加 到 [数据 连接 ] 下 ,如 图 10-4 所 示 。 

利用 [服务 器 资源 管理 器 面板 的 【数据 连接 ] 可 以 打开 数据 库 ASPNETDB, 从 图 10-5 
中 显示 出 的 数据 库 结 构 可 以 看 出 ,ASPNETDB 的 结构 很 复杂 ,其 中 包括 了 对 用 户 表 (aspnet 
_Users) .角色 表 (aspnet_Roles) 和 用 户 角 色 关 联 表 (aspnet_UserInRoles) 等 后 台数 据 表 的 
定义 。 

在 此 状态 下 ,可 以 像 操 作 普通 数据 库 一 样 操作 ASPNETDB 数据 库 , 执 行 诸如 添加 新 
表 、 设 置 表 间 关系 等 操作 。 开 发 者 甚至 可 以 把 自己 业务 活动 中 需要 处 理 的 数据 表 添 加 到 这 
个 数据 库 中 ,以 便 与 登录 模块 的 后 台数 据 表 整合 在 统一 的 体系 中 。 
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| | 时 国 aspnet personalizationPerUser 
| WB 目 aspnet profile 

| 由 国 aspnet Roles 
| | 申 国 aspnet SchemaVersions 


10-4 把 ASPNETDB 附加 到 服务 器 资源 管理 器 10-5 ASPNETDB 中 的 数据 表 


由 于 ASPNETDB 数据 库 中 与 登录 模块 相关 的 数据 表 是 为 适应 大 型 的 Web 系统 设计 
的 ,其 内 在 结构 和 关联 关系 都 比较 复杂 。 作 为 初学 者 ,不 必 对 以 aspnet 开头 的 数据 表 做 深 
入 的 研究 。 因 为 对 这 些 数据 表 的 操作 都 可 由 VS2008 内 置 的 控件 自动 完成 。 

注意 : 在 进行 VS2008 内 置 登录 模块 开发 的 过 程 中 ,请 断 开 服务 器 资源 管理 器 与 
ASPNETDB 的 连接 ,以 保证 登录 模块 控件 对 ASPNETDB 具有 和 较 高 的 控制 权限 ,避免 因 登 
录 控 件 对 ASPNETDB 的 操作 权限 不 足 而 引发 异常 。 

2. 内 置 的 登录 控件 与 类 

为 支持 登录 模块 开发 ,VS2008 在 工具 箱 中 专门 预 设 了 【登录 栏目 ,并 在 其 中 放置 了 7 个 
非常 重要 的 控件 : Login( 登 录 控件 ) .LoginView( 登 录 后 显示 视图 控件 )、PasswordRecovery( 密 
人 码 重 置 控件 ) 、LoginStatus (登录 状态 控件 )、LoginName( 登 录用 户 名 控件 )、CreateUserWizard 
(新 增 用 户 控件 ) 和 PasswordChange( 更 新 密码 控件 ) 。 

从 上 述 控件 名 称 可 知 , 对 于 登录 过 程 和 用 户 个 人 信息 管理 ,内 置 的 登录 控件 提供 了 非常 
强大 的 支持 。 但 对 角色 管理 .罗列 用 户 信息 、 设 置 用 户 角色 、 删 除 用 户 等 超级 管理 员 所 必需 
的 模块 ,上 述 控件 中 并 没有 提供 支持 。 为 此 ,VS2008 允许 开发 者 直接 调用 Membership 和 
Roles 两 个 类 ,利用 它们 提供 的 方法 完成 相关 操作 。Membership 类 中 的 重要 方法 如 表 10-1 
所 示 。 
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表 10-1 Membership 类 中 的 重要 方法 


方 法 名 用 途 
CreateUser() 添加 一 个 新 用 户 
DeleteUser() 删除 一 个 指定 用 户 
FindUsersByEmail() 根据 电子 邮件 信息 查找 用 户 
GetAllUsers() 获取 所 有 用 户 信息 的 列表 ,结果 可 直接 赋予 GridView 
GeneratePassword() 产生 一 个 特定 长 度 的 随机 密码 
ValidateUser() 实现 对 用 户 的 验证 


Roles 类 中 的 重要 方法 如 表 10-2 所 示 。 
表 10-2 Roles 类 中 的 重要 方法 


方 法 名 用 途 
AddUsersToRole() 把 用 户 添 加 到 某 一 角色 中 
RemoveUserFromRole() 从 指定 角色 中 删除 一 个 指定 用 户 
CreateRole() 创建 一 个 新 角色 
DeleteRole() 删除 一 个 指定 角色 
GetAllRoles() 获取 所 有 角色 的 列表 
GetUsersInRole() 获取 指定 角色 中 的 用 户 的 列表 
IsUserInRole() 判定 某 个 用 户 是 否 属于 某 种 角色 
RoleExists() 检测 是 否 已 经 存在 指定 的 角色 


注意 : 表 10-1 和 表 10-2 中 的 类 仅 适 合 于 VS2008 内 置 的 登录 模块 设计 ,与 其 相关 的 全 
部 操作 都 建立 在 对 数据 库 ASPNETDB 实施 操作 的 基础 上 。 

3. 网 站 管理 模块 

“网 站 管理 模块 "是 VS2008 为 Web 网 站 管理 而 专门 开发 的 一 个 模块 ,利用 此 模块 可 以 
实施 网 站 验证 方式 修改 、 添 加 用 户 与 删除 用 户 ,管理 角色 、 设 计 访 问 规则 等 操作 。 

此 模块 主要 是 为 系统 开发 者 初始 化 系统 状态 而 设计 的 。 当 开发 者 决定 使 用 VS2008 的 
内 置 登 录 控件 进行 登录 模块 的 开发 时 ,通常 都 会 利用 “网 站 管理 模块 "对 当前 应 用 程序 的 环 
境 进行 设置 ,临时 添加 几 个 初始 用 户 和 初始 角色 ,以便 在 程序 开发 过 程 中 调试 程序 。 

1) 启动 “网 站 管理 模块 

当 开 发 者 向 当前 窗 体 中 添加 Login 控件 后 ,只 需 单 击 Login 控件 右上 角 的 智能 按钮 就 
可 启动 智能 菜单 。 在 智能 菜单 下 选择 [管理 网 站 】, 系 统 会 启动 IE 浏览 器 ,进入 到 基于 浏览 
器 的 “网 站 管理 工具 ”状态 下 ,初始 界面 如 图 10-6 所 示 。 

在 “安全 ”选项 卡 下 , 单 击 “选择 身份 验证 类 型 ,系统 会 切换 到 新 的 页 面 中 ,请 开发 者 选 
择 站 点 的 访问 类 型 ,如 图 10-7 所 示 。 

如 果 决 定 使 用 Windows 验证 方式 进行 用 户 身份 验证 ( 即 只 允许 Windows 的 内 置 账号 
或 者 通过 局 域 网 用 户 访问 此 Web 应 用 程序 ) , 则 选择 【通过 本 地 网 络 】 单 选 按钮 。 

如 果 决 定 使 用 Forms 进行 验证 , 则 选中 【通过 Internet】 单 选 按钮 ,然后 单 击 右 下 角 的 
【完成 ] 按 钮 确认 设置 。 此 时 VS2008 会 自动 在 当前 项 目的 App_Data 文件 夹 下 创建 
ASPNETDB 数据 库 , 为 使 用 Forms 验证 做 好 准备 。 在 此 过 程 中 ,VS2008 还 会 修改 Web 
. config 文 件 中 的 相关 项 ,使 之 符合 Forms 验证 的 要 求 。 
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可 以 使 用 网 站 管理 工具 来 管理 应 用 程序 的 所 有 安全 设置 。 可 以 设置 用 户 和 密码 (身份 验证 )， 可 以 创建 
角色 (用 户 组 )， 还 可 以 创建 权限 (用 于 控制 对 应 用 程序 各 个 部 分 的 访问 的 规 风 ) 


默认 情况 下 ， 用 户 信息 存 灶 Microsoft SQL Server Express 教 据 库 中 ， 该 数据 库 在 网 站 的 Data 
文件 夹 中 。 如 果 要 将 用 户 信息 存 信 在 其 他 数据 库 中 ， 请 使 用 “提供 程序 ”选项 卡 选择 其 他 提供 程序 * 


使 用 安全 设置 向 导 按部就班 地 配置 去 全 性 。 


单 击 表 中 的 链接 以 管理 应 用 程序 的 设置 
现 有 用 户 : 1 未 启用 角色 他 时 访 间 规 则 
管理 用 户 创建 或 管理 角色 


CEasaaesa > 


10-6 【ASP.NET 网 站 管理 工具 界面 


| 
| 


用 户 将 如 何 访问 您 的 站 点 ? 


加 通过 Internet 


如 果 用 户 桂 通过 公共 Internet 访问 您 的 网站 ,请 
选择 此 选项 。 用 户 需要 使 用 Web 窗 体 登 录 。 站 点 
将 使 用 Forms 身份 验证 ,根据 存 铬 在 数据 库 中 的 
用 户 信息 来 识别 用 户 。 

司 通过 本 地 网 络 
如 果 用 户 仅 通过 专用 本 地 网 络 访问 您 的 网 站 ， 请 先 
择 此 选项 。 站 点 将 使 用 内 置 的 Microsoft 
Windows 身份 验证 来 识别 用 户 。 县 有 有 效 
Windows 用 户 名 和 密码 的 用 户 将 能 够 访问 您 的 站 
点 。 


图 10-7 设置 网 站 的 访问 类 型 


2) 创建 新 角色 

在 如 图 10-6 所 示 的 窗口 中 , 单 击 中 部 的 【启用 角色 链接 ,启用 角色 功能 。 然 后 单 击 【 创 
建 与 管理 角色 链接 ,切换 到 创建 新 角色 界面 ,如 图 10-8 所 示 。 

输入 角色 名 称 到 【新 角色 名 称 】 文 本 框 ,然后 单 击 【添加 角色 按钮 ,把 新 角色 添加 到 系统 
中 。 实 际 上 ,角色 信息 是 被 添加 到 了 ASPNETDB 数据 库 的 aspnet_Roles 数据 表 中 。 

3) 创建 新 用 户 

在 如 图 10-6 所 示 的 窗口 中 , 单 击 左下 部 的 【创建 用 户 ] 链 接 , 打 开 新 增 用 户 界面 ,如 
图 10-9 所 示 。 
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GO: [a hapy/ocalhoses9228 =[B [5 |x |[P Eee 
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页 | 用 程序 提供 程 库 
您 可 以 选择 添加 角色 或 组 ， 这 让 您 可 以 允许 或 拒绝 用 户 组 对 网 站 中 特定 文件 卖 的 访问 例如， 您 可 以 


创建 “经 理 ”、“ 销 售 人 员 " 或 “成员” 等 角色 ,每 种 角色 对 特定 文件 夹 都 具有 不 同 的 访问 权限 。 


创建 新 角色 


新 前 色 名 称 : 


图 10-8 设置 网 站 的 角色 


GO lar -alolxlP ae 7 
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Em 安 应 用 程 提供 程 有 


通过 在 本 页 上 输入 用 户 的 ID、 密码 和 电子 邮件 地 址 来 添加 用 户 。 
为 此 用 户 选择 角色 : 


加 过 书 台 
回 亲人 


安全 提示 问题 :你 的 小 学 琉 主 人 是 谨 9 
安全 答案 : 张 志 而 源 
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正确 地 输入 新 用 户 的 用 户 名 、 密 码 、 确 认 密 码 . 电 子 邮 件 信 息 ,而 且 预 设 一 个 只 有 用 
户 知道 答案 的 问题 ,并 给 予 正确 的 答案 ,以 备 万 一 遗忘 了 密码 ,可 以 通过 这 个 问题 及 其 回 
答 找 回 密 码 。 然 后 为 此 用 户 选 择 一 个 角色 。 最 后 单 击 【 创 建 用 户 ] 按 钮 ,就 会 创建 一 个 新 
用 户 。 

注意 : 由 于 ASP.NET 比较 注重 安全 机 制 , 因 此 对 密码 的 复杂 度 有 一 定 的 要 求 , 不 要 设 
置 过 于 简单 的 密码 。 不 然 可 能 会 被 系统 拒绝 ,无 法 注册 新 用 户 。 

4) 管理 用 户 或 角色 

在 [ASP.NET 网 站 管理 工具 界面 上 ,还 有 链接 “管理 用 户 ” 和 “创建 或 管理 角色 ”。 单 
击 对 应 的 链接 ,就 可 以 打开 相应 的 界面 ,执行 对 用 户 和 角色 的 管理 ,如 图 10-10 所 示 。 
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应 的 复 选 框 。 


着 要 末 止 该 用 户 登录 到 您 的 应 用 程序 ， 但 在 数据 库 中 保留 其 信息 ,可 通 过 清除 相应 的 复 先 卜 将 寺 


搜索 依据 : 用 户 名 ”搜索 内 容 : 


活动 ”用户 名 


10-10 利用 网 站 管理 工具 管理 用 户 ,设置 角色 
5) 添加 访问 规则 


VS2008 内 置 的 登录 体系 中 利用 项 目的 子 文件 夹 对 项 目 中 的 aspx 文档 进行 程序 归 类 ， 
因此 角色 对 应 用 程序 实施 访问 控制 也 是 通过 设置 角色 对 文件 夹 的 访问 权限 来 确定 的 。 因 
此 ,编辑 访问 规则 就 是 设置 每 个 子 文件 夹 针 对 某 一 角色 是 拒绝 访问 还 是 允许 访问 来 实现 的 。 


在 如 图 10-6 所 示 的 [ASP.NET 网 站 管理 工具 界面 上 , 单 击 右 侧 的 [创建 访问 规则 就 
可 以 打开 新 建 访问 规则 界面 ,如 图 10-11 所 示 。 


GO- | 本 hapylocalh- 目 国 四 因 | 隐 a 


实 届 天 着 AsPNet Web 应 用 民 - 


您 可 以 选择 添加 访问 规则 来 控制 对 整个 同 站 或 单个 文件 夫 的 访问 。 规 网 


可 应 用 于 特定 的 用 户 和 角色 、 所 有 用 户 、 匿 名 用 户 或 这 些 用 户 的 时 种 组 
合 。 规 刚 应 用 于 子 文件 夹 * 


添加 新 访问 规则 


为 此 规则 选择 一 个 目录 : 规则 应 用 于 : 
5 号 局 色 汪 
AMApp_Data 
用 户 


权限 : 


图 10-11 新 建 “访问 规则 ” 
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在 执行 [网 站 管理 工具 了 的 【启动 Internet 身份 认证 (Form 认证 )] 和 利用 [网 站 管理 工 
具 了 添加 了 几 个 临时 角色 和 临时 用 户 后 ,就 做 好 了 使 用 VS2008 内 置 的 成 员 资格 体系 开发 登 
录 模 块 的 准备 了 。 

6) 配置 站 点 ,使 之 可 自动 发 送 Email 

如 果 和 希望 站 点 具有 自动 发 送 Email 的 能 力 ,比如 购物 网 站 的 自动 发 送 订单 成 功 信息 、 自 
动 发 送 送 货 安排 信息 ,用 户 重 置 密码 时 Web 服务 器 自动 发 送 重 置 的 新 密码 等 ,都 需要 站 点 
具备 自动 发 送 Email 的 能 力 。 因 此 ,这 里 讨论 的 不 是 构建 Email 服务 器 ,而 是 为 站 点 提供 一 
个 向 外 发 送 Email 的 信息 通道 。 

在 [网 站 管理 工具 】 主 界面 中 ,选择 [应 用 程序 选项 卡 , 进 入 应 用 程序 配置 状态 ,从 中 间 
区 域 选择 超 链接 【配置 SMTP 电子 邮件 了 ,打开 如 图 10-12 所 示 的 界面 ,进行 配置 。 


pe nh ci i Fo 


OO le r/cane-. 昌国 四 四 | 加 ER pp 
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在 此 页 中 可 以 管理 SMTP 设置 ，SMTP 设置 确定 Web 应 用 程序 发 送 电子 邮件 的 
方式 。 如 果 您 的 电子 邮件 服务 器 要 求 先 登 录 ， 然 后 才能 发 送 电子 邮件 ， 请 指定 该 服 
务 器 所 要 求 的 身份 验证 类 型 ， 如 有 必要 ， 请 指定 要 使 用 的 用 户 名 和 密码 。 


注意 : 有 关 电 子 邮 件 服务 器 身份 验证 的 更 多 信息 ， 请 与 网 络 管理 员 联 系 。 


配置 SMTP 设置 


服务 器 名 : 。 smtp sina com 
服务 器 端口 : 25 


发 件 人 ; bnumxl 


身份 验证 : 
无 


加 基本 
如 果 您 的 电子 邮件 服务 器 要 求 在 发 送 电子 邮件 时 显 
式 传 入 用 户 名 和 密码 ， 请 选择 此 选项 * 


发 件 人 的 用 户 名 ; bnumxd 
发 件 人 的 害 玛 :seoe0oee 


NTUM (Windows 身份 验证 ) 

如 果 您 的 电子 邮件 服务 器 位 于 局 域 网 上 ， 并 且 您 使 

用 Windows 任 据 连接 到 该 服务 器 ,请 选择 此 迁 EE， 
项 。 


保存 


图 10-12 利用 [网 站 管理 工具 配置 网 站 自动 发 送 邮件 功能 


因 笔 者 在 新 浪 网 上 有 一 个 免费 信箱 bnumxl, 笔 者 希望 本 网 站 能 够 利用 新 浪 网 的 免费 邮 
箱 自动 发 送信 息 ,就 进行 了 如 图 10-12 所 示 的 配置 。 配置 信息 说 明了 负责 发 送 邮件 的 发 件 
服务 器 的 名 字 、 端 口号 以 及 发 送 人 的 账号 、 密 码 , 发 件 人 的 签名 信息 等 。 

本 配置 信息 被 自动 地 存储 到 项 目的 Web. config 文件 中 ,如 图 10-13 所 示 。 

4. 成 员 资格 配置 的 Membership 节 

在 VS2008 开发 工具 的 系统 文件 夹 Config 中 有 一 个 重要 的 配置 文件 Machine. config， 
在 其 中 有 专门 的 一 节 Membership, 是 专门 负责 对 成 员 资格 进行 配置 与 限制 的 。 

通常 情况 下 ,隶属 于 项 目 文件 夹 的 Web. config 从 Machine. config 中 继承 关于 


地 
时 
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26 system. net> 
27 <mailSettings> 
28: 《smtp from="bnumzl1"> 
129: network host="smtp. sina. com" password="mnl23456" userName="bnumxl" /> 
130 /smtp> 
131 /nailSettings> 
132: /system. net> 


图 10-13 发 送 邮件 功能 在 Web. config 中 的 配置 信息 


Membership 的 配置 信息 。 如 果 开 发 者 有 特殊 需要 ,可 以 把 这 一 节 复 制 到 项 目 配置 文件 
Web. config 文件 的 System. web 中 ,然后 修改 某 些 选项 的 值 ,如 图 10-14 所 示 。 


安全 


条 件 。 下 面 将 对 VS2008 的 登录 控件 进行 简单 的 介绍 。 


21 <membership> 
日 《providers> 

23 <clear /> 
24 汉 《add name="AspNetSqlMembershipProvider" 
25 type=" Systenm. Web. Security. SqlllenbershipProvider" 
26 cormectionStringName=" ‘LocalSqlServer" 
27 enablePasswordRetrieval=" "false” 
28 enablePasswordReset="true" 
29 requiresQuestionindAnswer=" true" 

30 applicationName="/" 


requiresliniqueEnail=" "false" 


39 /membership> 


32 passwordFormat="Hashed" 

33 naxInvalidPasswordAttempts="5" 

34 minRequiredPassyordLength="d" 

35 ninRequiredNonalphanunericCharacters="0" 
36 passwordAttemptWindow=" 10" 

37 passwordStrengethRegularExpression="" /> 
38 /providers> 


图 10-14 Web. config 中 的 成 员 资 格 管理 配置 节 


在 本 例 中 ,在 段 首 定义 部 分 增加 了 一 个 过 clear /> ,表示 不 使 用 Machine. config 内 关于 
membership 的 配置 ,而 是 直接 使 用 本 地 Web. config 的 配置 信息 。 另 外 ,本 例 把 密码 的 最 低 
长 度 修改 为 了 4, 使 用 户 的 密码 复杂 度 降低 ,减少 了 创建 新 用 户 的 难度 ,但 也 牺牲 了 一 部 分 


性 。 
10.3.2 ”内置 登录 体系 的 预 设 控件 


熟练 使 用 VS2008 提供 的 登录 控件 是 以 VS2008 的 内 置 登录 体系 编写 登录 模块 的 必要 


1. Login 控件 


Login 控件 用 于 实现 登录 界面 , 即 为 开发 者 提供 一 


个 输入 用 户 名 、 密 码 信息 的 表单 ,并 


能 够 对 用 户 提交 的 登录 信息 进行 验证 。 由 于 Login 控件 与 VS2008 内 置 的 用 户 管理 密切 集 
成 ,因此 其 验证 过 程 可 由 系统 自动 完成 而 不 需 编 写 C 划 代码 ,其 验证 凭据 为 已 经 存储 在 


ASP 


NETDB 数据 库 中 的 用 户 信息 。 


作为 一 款 功能 强大 的 控件 ,Login 控件 右上 和 角 的 智能 菜单 为 开发 者 美化 登录 面板 .进行 
个 性 化 设置 提供 了 方便 。 其 智能 菜单 中 的 【自动 套用 格式 ] 提 供 了 多 种 登录 模板 供 开 发 者 选 
用 ,【 管 理 网 站 ] 则 为 启动 网 站 管理 工具 实施 用户 管理 提供 了 入 口 。 

另外 ,Login 控件 还 提供 了 一 些 属性 ,通过 这 些 属性 可 以 完成 个 性 化 设置 ,如 表 10-3 
所 示 。 


属 性 
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表 10-3 ”Login 控件 的 属性 及 其 用 途 
说 明 信 息 


CreateUserText 


CreateUserUrl 


如 果 要 在 Login 中 增加 一 个 “注册 新 用 户 ” 的 链接 , 则 可 在 CreateUserText 
属性 上 给 予 提示 文字 ; 在 CreateUserUrl 属性 中 填写 负责 注册 新 用 户 的 那 
个 网 页 文档 的 程序 名 称 ,这 个 程序 通常 是 一 个 包含 CreateUserWizard 控件 
的 页 面 


DestinationPageUrl 


说 明 登 录 成 功 后 ,系统 要 跳 转 到 的 页 面 。 这 个 页 面 通常 是 一 个 包含 个 性 化 
菜单 的 页 面 , 因 此 其 中 通常 包括 LoginView 控件 


设置 是 否 在 登录 面板 上 显示 “ 记 住 我 ”的 复 选 框 。 默 认为 true, 即 显示 出 “ 记 


DisplayRememberMe 住 我" 复 选 框 

PasswordRecoveryText 设置 是 否 提供 密码 恢复 。 如 果 PasswordRecoveryText 属性 中 有 文本 信息 
(如 “我 忘记 密码 了 , 找 回 密码 ”) ,该 信息 将 被 显示 在 Login 控件 底部 ,而 

PasswordRecoveryUrl “| PasswordRecoveryUrl 则 链接 到 找 回 密 码 的 网 页 ,该 网 页 中 通常 包括 
PasswordRecovery 控件 

UserName 获取 或 者 设置 用 户 名 文本 框 的 数据 

Password 获取 用 户 提交 的 密码 数据 


2. CreateUserWizard 控件 
CreateUserWizard 控件 用 于 新 建 用 户 ,与 数据 库 ASPNETDB 中 的 aspnet_users 数据 
表 密 切 集成 ,能 够 快速 地 在 用 户 数据 表 中 增加 记录 。 


与 Login 一样 ,VS20 


08 也 为 CreateUserWizard 控件 设置 了 智能 菜单 ,允许 开发 者 通过 


智能 菜单 对 CreateUserWizard 控件 进行 配置 ,美化 界面 。 另 外 ,对 CreateUserWizard 最 关 
键 的 属性 就 是 ContinueDestinationPageUrl, 用 于 设 定 当 用 户 成 功 注册 户 后 系统 应 该 跳 转 到 
哪 一 个 网 页 。 除 此 之 外 ,还 有 儿 个 属性 也 需 注意 ,如 表 10-4 所 示 。 


属性 或 方法 名 


表 10-4 CreateUserWizard 控件 的 属性 和 方法 
说 明 信 息 


ContinueDestinationPageUrl 
LoginCreatedUser 
UserName 

Email 

UserName 

Password 
DisableCreatedUser 
CreatedUser 事件 


获取 或 设置 在 用 户 成 功 创建 新 用 户 后 需要 跳 转 到 的 目标 网 页 名 称 
设置 在 创建 新 用 户 后 是 否 以 新 用 户 登录 系统 

获取 或 设置 新 的 用 户 名 信息 

获取 或 设置 在 电子 邮件 文本 框 中 的 信息 

获取 或 者 设置 用 户 名 文本 框 的 数据 

获取 用 户 提交 的 密码 数据 

设置 是 否 允许 新 用 户 登 录 到 网 站 ,默认 为 false 

在 新 用 户 被 创建 后 触发 此 事件 。 通 常 可 在 此 事件 的 处 理 方法 中 包含 设 
置 新 用 户 角色 的 语句 


在 CreateUserWizard 控件 中 ,有 一 个 复合 属性 “MailDefinition”, 其 功能 是 自动 给 新 注 
册 用 户 发 送 Email, 即 向 新 注册 用 户 刚刚 登记 的 邮箱 中 发 送 一 封 Email, 如 图 10-15 所 示 。 

在 开始 配置 此 属性 前 ,必须 先 准备 好 一 个 纯 文 本 文档 ,用 于 保存 邮件 内 容 。 由 于 这 种 邮 
件 通常 属于 格式 公文 ,因此 邮件 的 主体 内 容 是 固定 的 ,只 是 收 件 人 的 用 户 名 和 密码 等 个 别 信 
息 不 同 。 因 此 ,在 这 种 文件 中 ,通常 使 用 二 % username % 这 和 二 % password ”记分 别 指 
代 收 件 人 ( 即 新 用 户 ) 的 用 户 名 密码, 然后 适当 撰写 感谢 注册 、 感 谢 注 册 ” 之 类 的 句子 。 
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如 图 10-15 所 示 , 子 属性 BodyFileName 用 于 指定 存放 邮件 内 容 的 文件 的 名 称 ; CC 则 
是 抄 送 地 址 ; From 指明 发 件 人 地 址 ,通常 是 站 点 负责 
人 的 邮箱 地 址 ; Subject 说 明 邮 件 的 主题 。 

注意 : 使 用 此 功能 的 前 提 条 件 是 : 已 经 在 “网 站 管 
理 ” 界 面 中 配置 好 了 “SMTP 电子 邮件 ”。 

3. LoginName 控件 

LoginName 控件 是 一 个 非常 简单 的 控件 ,用 于 显 
示 成 功 登录 者 的 用 户 名 。 它 不 仅 可 以 用 来 显示 Forms 
验证 的 用 户 名 ,而且 还 可 以 显示 在 以 其 他 验证 方式 登 
录 系 统 之 后 的 用 户 名 。 

图 10-15 设置 CreateUserWizard 的 LoginName 的 属性 FormatString 用 于 设置 输出 

自动 发 送 邮 件 功能 的 用 户 名 格式 ,其 格式 串 支持 常用 的 字符 串 格式 定义 
及 字符 串 参数 。 例 如 用 户 名 “Zhang001? 正 确 登录 系统 ,如 果 设 置 FormatString 王 "热烈 欢 
迎 (0) 登 录 本 系统 1" ,那么 将 会 在 放置 LoginName 的 位 置 显示 出 “热烈 欢迎 Zhang001 登录 
本 系统 1”。 

在 Web 应 用 系统 开发 中 ,如 果 开 发 者 需要 使 用 登录 者 的 用 户 名 填充 某 些 更 新 操作 的 
“操作 人 "文本 框 ,为 更 新 操作 保留 痕迹 , 则 可 以 使 用 User. Identity. Name 获取 当前 用 户 的 
用 户 名 。 事 实 上 ,LoginName 控件 也 是 从 这 个 变量 中 获取 数据 的 。 

4. LoginStatus 控件 

LoginStatus 控件 又 称 为 登录 状态 控件 , 它 能 够 获取 用 户 登 录 网 站 的 状态 。 如 果 用 户 未 
登录 ,系统 应 处 于 可 执行 登录 程序 的 状态 ,因此 ,该 控件 应 该 链接 到 登录 页 面 上 ,并 显示 为 
“登录 ”标志 ,表示 只 要 用 户 单 击 “ 登 录 ” 链 接 , 就 会 跳 转 到 登录 页 面 。 反 之 。 如 果 用 户 已 经 登 
录 , 系 统 就 已 处 于 可 随时 退出 登录 的 状态 ,因此 该 控件 应 该 链接 到 注销 页 面 上 ,并 显示 为 “ 注 
销 ?或 “退出 系统 ”的 标记 。 

LoginStatus 控件 提供 了 多 个 与 登录 状态 相关 的 属性 ,如 导航 到 登录 页 面 的 链接 .导航 
到 注销 页 面 的 链接 等 ,常见 的 属性 如 表 10-5 所 示 。 


表 10-5 LoginStatus 控件 的 主要 属性 


CreateUserWizard1 System.Web.ULWebControlsC ~ 


CC 
EmbeddedObjeds 。。 俯 后 ) 
From 

IsBodyHtml False 


Priority Normal 
Subject 
Membershipprovider 
田 NavigationButtonSble 
田 NavigationStyle 
PasswordHintStyle 


属 性 名 含义 

LoginText 链接 到 登录 页 面 的 导航 信息 ,默认 为 “登录 ”二 字 

LoginImageUrl 如 果 以 图 片 作为 链接 到 登录 页 面 的 导航 信息 , 则 以 此 属性 指定 图 片 文件 
的 URL 

LogoutImageUrl 如 果 以 图 片 作为 链接 到 注销 页 面 的 导航 信息 , 则 以 此 属性 指定 图 片 文件 
的 URL 

LogoutText 链接 到 注销 页 面 的 导航 信息 ,默认 为 “注销 ”二 字 

LogoutPageUrl 执行 注销 后 转向 的 页 面 

LogoutAction 执行 注销 操作 后 系统 下 一 步 的 动作 ,有 三 个 选项 


Redirection: 跳 转 到 指定 URL 的 网 页 ,URL 值 由 LogoutPageUrl 指定 
@ Refresh: 刷 新 当前 页 面 
@ RedirectToLoginPage: 跳 转 到 指定 的 登录 页 面 
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注意 : 在 本 控件 中 ,没有 LoginPageUrl 属性 ,不 能 在 此 控件 内 指定 登录 页 面 的 URL， 
它 使 用 系统 默认 的 登录 页 面 文件 Login. aspx。 系 统 默认 登录 页 面 的 URL 指向 项 目 根 目录 
下 的 文档 Login. aspx。 如 果 确 实 需要 修改 默认 的 登录 页 面 , 则 可 以 修改 配置 文档 Web 
.config, 在 此 文档 的 二 authentication mode 一 "Forms" 盖 的 下 面 添加 一 行 <forms loginUrl 王 登 
录 文 件 名 . aspx" 盖 一 /forms 之 ,用 于 声明 系统 的 登录 文件 是 什么 名 称 。 

5. LoginView 控件 

1) LoginView 控件 的 用 途 

LoginView 控件 又 称 为 登录 视图 控件 , 它 根据 用 户 是 否 登 录 网 站 以 及 用 户 的 角色 来 显 
示 不 同 的 内 容 。 

从 Web 应 用 系统 的 用 户 来 讲 ,主要 有 3 类 成 员 : 匿名 用 户 已 登录 但 无 角色 的 用 户 、 具 
备 一 定 角色 的 用 户 。 而 具备 一 定 角色 的 用 户 又 可 根据 角色 划分 为 不 同 的 权限 组 。 因 此 ,从 
严格 意义 上 讲 , Web 程序 的 用 户主 要 为 1 十 1 十 X 类 ,其 中 XX 特 指 是 每 一 种 角色 。 

LoginView 控件 包括 两 个 模板 : AnonymousTemplate 和 LoggedInTemplate。 第 一 个 
模板 用 于 定义 针对 匿名 用 户 ( 未 登录 用 户 ) 的 显示 内 容 ; 第 二 个 模板 又 可 以 被 定义 为 1 十 X 
个 子 模板 ,其 中 的 1 面向 “已 登录 但 无 角色 配置 "的 用 户 ,另外 的 X 个 模板 则 面向 各 种 角色 
用 户 。 下 面 将 通过 一 个 实例 说 明 LoginView 控件 的 设计 过 程 。 

2) LoginView 控件 用 法 示例 

假设 要 设计 一 个 图 书馆 内 部 管理 系统 ,在 此 系统 下 ,学 生 为 匿名 用 户 , 图 书馆 全 体 员 工 
都 是 登录 用 户 ,但 只 有 少量 职工 承担 着 借 书 、 还 书 、 图 书信 库 、 图 书 报废 的 业务 ,与 信息 有 着 
密切 的 关系 。 因 此 开发 者 为 此 系统 设置 了 4 种 角色 ,分 别 是 借 书 员 、 还 书 员 、 入 库 员 报废 
员 , 分 别 以 拼音 命名 为 Jieshu、Huanshu、Ruku、BaoFei。 现 在 为 此 系统 设计 LoginView。 

首先 ,添加 LoginView 控件 , 即 向 窗 体 中 添加 LoginView 控件 ,更改 其 ID 为 lvTsg。 

其 次 ,添加 角色 。 打 开 其 智能 菜单 ,选择 【编辑 RoleGroups】 选 项 , 则 打开 一 个 
【RoleGroups 集合 编辑 器 】〗 对 话 框 ,如 图 10-16 所 示 , 把 上 述 4 种 角色 添加 到 
RolesGroups 中 。 


威 员 (M) Baofei 必 性): 
日 融 a 一 
一 - » Roles Baofei 
区 一 到 

天 十 取消 


10-16 为 LoginView 添加 角色 、 创 建 相应 的 角色 面板 
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最 后 ,分 别 设计 各 类 显示 模板 。 打 开 LoginView 的 智能 菜单 ,从 中 选择 一 种 模板 ,然后 
在 LoginViewl 下 面 的 窗 体 中 编辑 。 例 如 ,可 把 登录 状态 控件 LoginStatus、 关 于 公告 等 公 
开 信息 的 链接 添加 到 Anonymous Template 面板 中 ; 把 有 关 还 书 操作 的 超 链接 添加 到 
【RoleGrop[1]-Huanshu] 的 面板 中 ,如 图 10-17 所 示 。 

总 之 ,LoginView 是 成 员 资 格 管理 中 用 于 实现 个 性 FE 
化 菜单 的 重要 手段 , 它 能 保证 各 类 用 户 仅 能 操作 自己 职 ”Ee 
权 范 围 内 的 业务 。 

6. ChangePassword 控件 

ChangePassword 控件 用 于 修改 用 户 的 密码 。 它 提 RoleGroupl] > Hanshi 
供 了 两 个 视图 : 更 改 密码 视图 和 成 功 视图 。 顾名思义 ,更 ers 
改 密码 视图 提供 了 两 个 更 改 密码 的 操作 界面 。 已 登录 用 
户 修改 密码 的 视图 如 图 10-18 所 示 , 未 登录 后 用 户 修改 密 图 10-17 在 LoginView 内 选择 一 


码 的 视图 如 图 10-19 所 示 。 种 面板 并 进行 编辑 
更 改 密码 
密码 
新 密码 
确认 新 客 码 。 
更 效 到 再 | 取消 | 
图 10-18 已 登录 用 户 更 改 密码 图 10-19 未 登录 用 户 更 改 密码 


系统 默认 为 不 允许 未 登录 用 户 修改 密码 。 如 果 和 希望 未 登录 用 户 也 可 以 修改 密码 , 则 需 
要 把 属性 DisplayUserName 设置 为 true。 因 为 只 有 更 改 DisplayUserName 为 true 后 ,系统 
才能 知道 未 登录 用 户 想 更 改 哪个 账户 的 密码 。 

在 “成 功 视图 ”中 提供 了 一 个 更 改 密码 成 功 的 提示 信息 ,而 且 有 一 个 [成 功 ] 按 钮 ,可 利用 
SuccessPageUrl 属性 为 此 按钮 设置 一 个 跳 转 的 页 面 。 

如 果 站 点 已 经 配置 过 SMTP, 则 可 以 为 ChangePassword 属性 配置 MailDefinition 属 
性 ,使 站 点 在 修改 密码 成 功 后 自动 给 用 户 发 送 Email。 

注意 ; 不 论 已 登录 用 户 , 还 是 未 登录 用 户 , 要 想 更 改 密码 ,都 必须 知道 原 密码 ,而 且 新 设 
置 的 密码 要 符合 密码 设置 规范 。 

7. PasswordRecovery 控件 

PasswordRecovery 控件 被 称 为 密码 重 置 控件 ,其 主要 服务 于 用 户 因 密码 遗忘 而 需要 重 
新 找 回 密码 的 情形 。 当 用 户 遗 忘 密码 后 ,如 果 需 要 找 回 密码 , 则 单 击 【密码 重 置 ] 链 接 , 此 时 
启动 密码 重 置 控件 。 通 常情 况 下 ,系统 要 求 用 户 回答 注册 时 预 设 的 安全 问题 ,如 果 能 够 正确 
答 出 安全 问题 的 答案 ,系统 就 会 自动 把 原来 的 密码 或 者 系统 重新 设置 的 密码 通过 Email 发 
送 到 用 户 的 邮箱 中 。 

如 果 站 点 的 二 membership 记 中 把 PasswordFormat 设置 为 Clear 或 Encrypted 模式 , 系 
统 会 采用 发 回 原 密码 的 方式 ; 如 果 站 点 的 membership 之 中 把 PasswordFormat 设置 为 
Hashed 模式 ,系统 就 会 重新 自动 生成 一 个 随机 密码 发 送 给 用 户 , 用 户 可 以 使 用 此 随机 密码 
登录 系统 ,然后 重新 修改 密码 。 
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Aé 


当 把 PasswordRecovery 控件 放置 到 窗 体 中 ,运行 窗 体 后 ,得 到 的 效果 如 图 10-20 和 
图 10-21 所 示 。 


标识 确认 
要 接收 您 的 密码 ， 请 回答 下 列 问题 。 
用 户 名 ma 


A 
要 请 和 用， i 
和 


ED EE 到 


图 10-20 密码 重 置 的 第 1 步骤 图 10-21 密码 重 置 的 第 2 步骤 


10.3.3 基于 内 置 的 成 员 资 格 管理 开发 登录 模块 


1. 案例 的 基本 要 求 

红星 图 书馆 需要 设计 一 个 图 书馆 内 部 管理 系统 。 在 此 系统 下 ,学 生 为 匿名 用 户 ,图 书馆 
全 体 员 工 都 是 登录 用 户 ,但 只 有 少量 职工 承担 着 借 书 、 还 书 、 图 书 入 库 、 图 书 报废 的 业务 ,与 
内 部 信息 处 理 有 着 密切 的 关系 。 因 此 开发 者 为 此 系统 设置 了 4 种 角色 ,分 别 是 借 书 员 、 还 书 
员 、 人 库 员 ,报废 员 , 并 计划 分 别 以 拼音 命名 为 Jieshu、Huanshu、Ruku、BaoFei。 另 外 ,需要 
为 管理 员 增 加 一 种 角色 Admin。 

2. 系统 模块 设计 与 命名 规范 

根据 题目 要 求 ,系统 规划 以 VS2008 内 置 的 成 员 资格 管理 体系 实施 用 户 管理 。 

首先 预 设 全 局 性 程序 名 称 : 首页 窗 体 名 Default. aspx, 登 录 窗 体 名 Login. aspx, 新 
建 用 户 窗 体 名 NewUser. aspx, 修改 密码 窗 体 名 ChangePwd. aspx, 重 置 密码 窗 体 名 
PwdRecover. aspx, 项 目的 主 界面 与 个 性 菜单 窗 体 名 BookMain. aspx, 超 级 用 户 管理 用 户 和 
角色 的 窗 体 UserRole. aspx。 

预 设 4 个 文件 夹 , 分 别 存储 与 借 书 、 还 书 、 入 库 、 报 废 4 个 环节 有 关 的 Web 窗 体 文档 ,而 
且 借 书 模块 的 首页 命名 为 Borrow. aspx', 还 书 模块 的 首页 命名 为 BookBack. aspx, 入 库 模块 
的 首页 命名 为 BookStore. aspx, 而 报废 模块 的 首页 命名 为 : BookBad. aspx。 

另外 , 预 设 两 个 纯 文 本 文档 。 一 个 用 于 感谢 用 户 的 注册 ,命名 为 Thank. txt; 一 个 用 于 
发 回 重 置 密码 ,命名 为 Pwdmm. txt。 

3. 新 建 项 目 并 实现 网 站 配置 

(1) 新 建 一 个 Web 项 目 , 命 名 为 HxBookAuto, 然 后 新 增 一 个 Web 窗 体 ,命名 为 
Login. aspx, 存 放 在 项 目的 根 文件 夹 下 。 

(2) 根据 规划 在 项 目下 创建 4 个 文件 夹 。 

(3) 从 [工具 箱 ] 中 拖 动 一 个 Login 控件 到 Login 窗 体 中 ,利用 其 智能 菜单 项 中 的 【管理 
网 站 启动 网 站 管理 工具 。 在 网 站 管理 工具 下 ,完成 以 下 配置 工作 。 

首先 ,启动 “通过 Internet” 方 式 实现 身份 验证 ( 即 Forms 方式 ) 。 

其 次 ,启用 角色 ,然后 创建 题目 要 求 的 5 个 新 角色 。 

第 三 ,创建 用 户 ,并 分 别 为 每 个 用 户 设置 角色 。 至 少 为 每 种 角色 中 添加 1 个 用 户 。 

第 四 ,创建 超级 用 户 super( 当 然 ,此 用 户 的 用 户 名 也 可 随便 定义 ), 但 它 隶 属于 Admin 角色 。 

第 五 ,启动 SMTP 电子 邮件 。 利 用 自己 现 有 的 电子 邮箱 的 参数 配置 服务 器 的 电子 邮 
件 , 使 站 点 能 够 向 外 发 送 电子 邮件 。 
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最 后 ,创建 访问 规则 ,建立 文件 夹 与 角色 之 间 的 管理 关系 。 

注意 : 角色 Admin 对 所 有 文件 夹 都 具有 “允许 ”的 权限 。 

(4) 回 到 Default. aspx 文档 ,在 其 中 添加 一 个 超 链接 “登录 ” ,链接 到 文档 Login. aspx。 
4. 配置 Login 对 象 

在 Login. aspx 窗 体 中 选择 Login 控件 ,对 其 属性 进行 如 表 10-6 所 示 的 配置 。 


表 10-6 ”对 Login 控件 的 各 属性 的 配置 什 


属性 名 设 定 值 
CreateUserText 注册 新 用 户 
CreateUserUrl NewUser. aspx 
DestinationPageUrl BookMain. aspx 
DisplayRememberMe true 
PasswordRecoveryText 我 忘记 密码 了 , 找 回 密码 ! 
PasswordRecoveryUrl PwdRecover. aspx 


5. 创建 并 配置 NewUser.aspx 文档 

(1) 在 项 目 HxBookAuto 中 新 增 窗 体 NewUser. aspx。 

(2) 在 窗 体 中 新 增 控件 CreateUserWizard, 然 后 选 定 CreateUserWizard 控件 ,对 其 属 
性 进行 如 表 10-7 所 示 的 配置 。 


表 10-7 对 CreateUserWizard 控件 的 各 属性 的 配置 值 


属 性 名 设 定 值 
ContinueDestinationPageUrl Login. aspx 
LoginCreatedUser false 
DisableCreatedUser false 
MailDefinition/ BodyFileName Thank. txt 
MailDefinition/ From 请 输入 网 管 的 邮箱 地 址 
MailDefinition/ Subject 感谢 您 注册 本 网 站 ,欢迎 光临 ! 


(3) 为 Thank. txt 输入 内 容 , 如 图 10-22 所 示 。 


<br > 亲爱 的 <% username%>, 您 好 : < br > 

非常 感谢 您 在 本 网 站 注册 。 下 面 是 您 在 本 网 站 的 注册 信息 。 请 您 注意 保管 好 自己 的 密码 和 用 户 
名 。 为 了 您 的 账户 安全 ,阅读 本 邮件 完毕 ,请 您 务必 删除 本 邮件 。< br > 

用 户 名 : <% username %><br> 

密码 : <% password %> 


图 10-22 当 创建 用 户 成 功 后 ,发送 给 用 户 的 信件 内 容 


说 明 : 邮件 内 容 中 用 二 %% 沁 标记 的 内 容 为 变量 ,在 发 送 邮 件 时 系统 会 自动 填 入 对 应 
的 信息 。 

6. 创建 并 配置 ChangePwd. aspx 文档 

(1) 在 项 目 HxBookAuto 中 新 增 窗 体 ChangePwd. aspx。 

(2) 在 窗 体 中 新 增 控件 ChangePassword ,然后 选 定 ChangePassword 控件 ,对 其 属性 进 
行 如 表 10-8 所 示 的 配置 。 
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表 10-8 ”ChangePassword 控件 的 属性 配置 值 


属 性 名 设 定 值 
SuccessPageUrl Login. aspx 
DisplayUserName false 


7. 创建 并 配置 PwdRecover.aspx 文档 

(1) 在 项 目 HxBookAuto 中 新 增 窗 体 PwdRecover. aspx。 

(2) 在 窗 体 中 新 增 控件 PasswordRecovery, 然 后 选 定 PasswordRecovery 控件 ,对 其 属 
性 进行 如 表 10-9 所 示 的 配置 。 


表 10-9 PasswordRecovery 控件 的 属性 配置 值 


属 性 名 设 定 值 
SuccessPageUrl Login. aspx 
MailDefinition/ BodyFileName Pwdmm. txt 
MailDefinition/From 请 输入 网 管 的 邮箱 地 址 
MailDefinition/ Subject 您 的 密码 已 经 被 重 置 ,欢迎 您 使 用 新 密码 登录 系统 ! 


8. 创建 并 配置 BookMain. aspx 文档 

(1) 在 项 目 HxBookAuto 中 新 增 窗 体 BookMain. aspx。 

(2) 在 窗 体 中 新 增 控件 LogView, 然 后 选 定 LogView 控件 ,利用 其 智能 菜单 进行 以 下 配置 。 

首先 ,选择 【编辑 Roles Groups】, 在 弹出 的 对 话 框 中 登记 5 个 角色 组 。 

其 次 ,从 智能 菜单 中 选择 模板 Anonymous Template, 然 后 设置 此 模板 ,输入 “您 还 没有 
登录 ”和 一 个 LoginStatus 控件 。 当 然 还 可 以 放置 其 他 的 文本 、 图 片 等 公开 信息 。 

最 后 ,从 智能 菜单 中 选择 一 种 角色 模板 进行 设置 。 例 如 ,对 于 RoleGroups[0]-jieshu 
(面向 借 书 台 工 作 人 员 ) 模 板 , 可 以 添加 一 个 LoginName 控件 一 个 链接 到 Borrow. aspx 窗 
体 的 超 链接 和 一 个 LoginStatus 控件 ,当然 还 可 以 包括 修改 密码 的 超 链接 等 。 

同 理 , 对 其 他 模板 进行 设置 。 

9. 创建 用 户 和 角色 管理 程序 

在 Web 应 用 系统 中 ,超级 管理 员 具 有 用 户 管理 和 角色 管理 的 权限 ,他 能 够 创建 新 用 户 
并 为 用 户 设 定 角色 。 为 此 ,需要 为 超级 管理 员 设 计 用 户 和 角色 管理 程序 。 程 序 的 运行 界面 
如 图 10-23 所 示 ,要 求 程序 能 够 显示 并 删除 用 户 ,而 且 能 够 直接 为 用 户 设置 角色 。 

(1) 在 项 目 HxBookAuto 中 新 增 窗 体 UserRole. aspx, 然 后 请 把 此 窗 体 保存 在 只 有 
Admin 角色 有 访问 权 的 安全 文件 夹 中 。 

(2) 在 窗 体 中 增加 必要 的 说 明文 字 , 然后 添加 一 个 GridView 控件 ,其 ID 为 
GridView1, 并 利用 智能 菜单 套用 “秋天 ”格式 ; 添加 一 个 Label 控件 ,ID 修改 为 lblUser; 再 
添加 一 个 CheckBoxList 控件 ,其 ID 修改 为 cbl, 最 后 添加 一 个 Button 控件 ,其 ID 修改 为 
btnRole, Text 属性 设置 为 “设置 用 户 角色 ”。 

(3) 利用 GridView 的 智能 菜单 对 它 的 输出 列 进行 配置 。 即 打开 其 【字段 ] 对 话 框 ,如 
图 10-24 所 示 。 取 消 选中 左下 角 的 “自动 生成 字段 " 复 选 框 ,为 此 控件 增加 3 个 BoundField 
列 和 两 个 CommandField 列 。 
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Nt 


OO 出 mapyacah- ~[B 1 [xP Bas 


文件 日。、 坊 四 ”二 W 收工 上 (天 肌 MH 


六 WE 逢 天 ES 全 "加 "口外 
用 户 与 角色 管理 程序 
用 户 名 电子 邮件 创建 日 期 | 选择 用 户 | 删除 用 户 
mad md@1234com 2011/211 ”选择 删除 
wangdian wxpl2@126com 2011211 ”选择 删除 
wangma wwwwww@126com 20112/11 选择 删除 
wangm abc@l23com ”20112/11 选择 删除 
已 Adman 
Baofei 
选 定 的 用 户 名 :Label 。 目 Huansim 
jesho 
目 Rulm 
设置 用 户 角色 


图 10-24 编辑 GridView( 输 出 用 户 信息 ) 的 列 的 信息 


(4) 设置 第 一 列 的 DataField 为 “username”、HeaderText 为 “用 户 名 ”; 第 二 列 的 
DataField 为 “Email”、HeaderText 为 “电子 邮件 ”, 第 三 列 的 DataField 为 “CreationDate”、 
HeaderText 为 “创建 日 期 ”, 并 把 DataFormatString 属性 设置 为 “{0:d}”。 

说 明 ; 本 例 中 DataField 中 的 值 就 是 memebership 类 中 的 列 名 。 因 在 运行 时 需要 从 
membership 的 对 应 列 中 提取 数据 ,因此 绝 不 能 输 错 。 

(5) 设置 GridView 的 AutoPaging 属性 为 true, PageSize 属性 值 为 5; 然后 为 GridView 的 
三 个 事件 PageIndexChanging SelectedIndexChanged 和 RowDeleting 添加 方法 代码 。 最 后 
为 按钮 Button 的 Click 事件 添加 方法 代码 。 

(6) 代码 设置 完成 后 ,运行 程序 ,测试 其 效果 。 

最 终 得 到 的 程序 如 图 10-25 所 示 。 
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14 日 namespace LoginAuto 
15i| { 


169 public partial class lserRole : System. Web. UI.Page 
17 { 
18 void showhlllsers() // 自 定义 方法 ， 显 示 所 有 用 户 
19 { 
20 MembershipUserCollection users = Nenbership.GetAllUsers!(); 
vl /7 获 取 用 户 表 的 所 有 用 户 
22 GridViewl.DataSource = users; // 把 用 户 序 列 绪 定 到 GridView 
23 Gridyiewvl.DataBind() ; 
24 ] 
25 扣 protected void Page_Load(object sender, Eventhres e) 
26 { 
27 这 (IIsPostBack) 
28 { 
29 String[] roles = Roles,GetAllRoles() ; // 获 取 全 体 角 色 信 息 
30 cbl. Itens. Clear (); 1/ 清空 CheckBoxList 的 选项 
31 for (int i = 0; i < roles.Length; i++) 
32 { /1 把 角色 信息 瀛 加 到 CheckBoxList 中 
了 cbl. Itens. Add(roles[i]); 


} 
j showhllUsers () ; // 调 用 自 定义 的 show&11Users， 显 示 GridView 
} 


protected void btnRole ek bye sender, Eventhrgs gs e) 
{ 函数 的 功能 是 把 设置 的 角色 保存 起 来 
String []uname = new strine ti 


mane [0]=lbluser. Text ; // 把 Labe1 中 显示 的 用 户 名 转换 为 String 型 数组 
for (int i = 0; i 《< cbl.Items.Count; it+) // 逐 个 角色 进行 检查 


String rnane = cbl. Itenms[i].Text.Trin(); 
if (cbl. Itens [i].Selected 艇 IRoles. Dearielime lh, rname)) 
Roles, AddUsersToRole (unane, rname) 
// 如 果 当 前 角色 被 选 定 而 且 用 户 不 在 当前 角色 中 ， 则 把 用 户 加 入 到 角色 中 
if (Icbl. Itens[i].Selected && Roles. 人 rname)) 
Roles, RenovelserFronRole (name [0], 


} 


protected void GridYiewl_SelectedIndexChanged (object sender, Eventhres e) 
{ // 本 国 数 用 于 响应 某 一 用 户 被 选 定 事件 

int nun = GridViewv1.SelectedIndex ; 

String uname = GridYiewl.Rows [num].Cells[0], Text; 


lbluser. Text = unane;  // 获 取 被 选 定 用 户 的 用 户 名 
(int 1 = 0; i < cbl.Itenms,Count ; 


否则 复 选 框 置 为 没有 选中 状态 
em rnane = cbl. Ttens [i]. Text. Trin() : 
if (Roles. IsUserInRole (uname, rname)) cbl. Items[i].Selected=true; 
! else cbl. Itens [i] .Selected = false; 
} 


GridyiewRow gvr = Gridyiewl,Rows[e,RovIndex] : 

String unane=gvr.Cells[0]. Text; // 注 意 用 户 名 在 第 0 列 
Jlembersh:p.DeletelUser (uname) ; ”// 暗 除 选 定 F 
showhllUsers () ; // 重 新 显示 


开本 
本 


GridViewl.PageIndex = e.NewPageIndex: ”// 响 应 换 页 事件 
showhllllsers () ; 


// 如 果 当 前 角色 没 被 选 定 但 用 户 在 当 前 角色 中 “ 尖 反 用户 从 当前 角色 中 轴 除 


i++) 
ped 逐个 角色 进行 接 查 ， 着 用 户 居于 此 角色 ， 则 复 选 框 设 为 选中 状态 ， 


protected void GridViewl_RovDeleting (object sender, GridViewDeleteEventAres e) 
{ 


protected void GridYiew!_PageIndexChanging (object sender, GridYiewPageEventhrgs e) 
{ 


图 10-25 用 户 与 角色 设置 程序 的 C# 源 代码 
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注意 : 在 实际 的 Web 项 目 开发 中 ,为 避免 非法 用 户 越 过 登录 界面 直接 访问 本 页 ,往往 
需要 采取 以 下 技术 措施 。 

其 一 ,把 本 文件 放 在 特殊 的 文件 夹 中 ,通过 访问 规则 进行 限制 。 

其 二 ,在 本 页 面 的 Page_Load 中 添加 两 个 语句 ,首先 利用 Roles. GetRolesForUser 
(User. Identity. Name) 获 得 当前 用 户 的 角色 名 数组 ,然后 进行 判定 : 如 果 Admin 不 在 此 数 
组 中 , 则 当前 用 户 无 权 访 问 本 页 ,就 直接 利用 Response. Redirect 语句 跳 转 到 另外 的 页 
面 上 。 


fo.4 自主 开发 登录 模块 


VS2008 内 置 的 成 员 资 格 管理 体系 为 登录 模块 的 设置 提供 了 极 大 的 便利 ,但 其 后 台数 
据 库 的 复杂 性 和 配置 的 烦琐 性 也 使 许多 开发 者 望而却步 。 另 外 ,在 VS2005 出 现 以 前 的 时 
代 , 许 多 程序 员 已 经 熟悉 了 使 用 Session 自行 开发 登录 系统 的 模式 ,这 一 模式 仍然 在 Web 项 
目 广 泛 地 使 用 。 为 此 ,下 面 将 对 自行 开发 登录 模块 .设置 用 户 和 角色 问题 进行 探索 。 


10.4.1 自主 开发 登录 模块 的 设计 思 # 


自主 开发 登录 模块 的 设计 思路 也 遵循 Forms 验证 的 思想 ,其 基本 流程 如 下 。 

首先 ,开发 者 自行 创建 后 台数 据 库 , 并 在 数据 库 中 创建 用 户 表 和 角色 表 , 保 存 合法 用 户 
的 用 户 信息 和 角色 信息 。 

其 次 ,开发 登录 验证 程序 。 而 登录 验证 程序 的 关键 任务 就 是 创建 一 个 表单 ,使 访问 者 可 
以 通过 表单 提交 用 户 名 .密码 等 身份 信息 。 由 验证 程序 到 后 台数 据 库 的 用 户 表 检 索 刚 提交 
的 用 户 名 是 否 存 在 、 密 码 是 否 有 效 。 

再 次 ,如 果 访 问 者 提交 的 用 户 名 和 密码 通过 了 验证 , 则 立即 读 取 其 角色 信息 ,并 把 用 户 
名 、 角 色 等 关键 信息 存储 到 Session 变量 中 。 

最 后 ,在 各 应 用 程序 的 Page_Load 函数 中 增加 判定 语句 。 利 用 Page_Load 中 的 判定 语 
句 限制 可 以 访问 当前 窗 体 的 角色 的 名 称 。 如 果 当 前 用 户 的 角色 名 不 属于 当前 页 面 判定 语句 
的 允许 范围 , 则 系统 直接 跳 转 到 其 他 的 页 面 ,或 者 直接 给 予 一 个 严重 的 警示 信息 。 

总 之 ,自主 开发 登录 模块 的 思想 可 以 归结 为 一 句 话 :“ 以 数据 表 为 基准 ,以 Session 做 
控制 ”。 

自主 开发 登录 模块 的 程序 流程 图 如 图 10-26 所 示 。 


10.4.2 自主 开发 登录 模块 设计 实例 


针对 前 节 提 出 的 红星 图 书馆 信息 系统 自主 开发 一 套 登 录 模块 ,其 基本 过 程 如 下 。 

1. 创建 后 台数 据 库 

(1) 利用 [服务 器 资源 管理 器 ] 面 板 的 [数据 连接 】 ,启动 [创建 新 的 SQL Server 数据 库 】 
对 话 框 ,如 图 10-27 所 示 。 

(2) 在 此 数据 库 中 创建 “角色 表 ”, 其 结构 定义 为 角色 号 、 角 色 名 、 角 色 含 义 。 设置“ 角色 
号 ”为 主键 。 
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提取 该 用 户 的 密码 


N 


密码 正确 否 ? 


产生 三 个 Session 变 量 

一 个 标记 是 否 登录 

一 个 记录 登录 者 的 用 户 名 
-个 记录 登录 者 的 操作 权限 


执行 查询 语句 


查找 用 户 名 跳 转 到 系统 的 主 界 面 


图 10-26 通用 的 登录 模块 的 程序 流程 图 


(3) 在 此 数据 库 中 创建 “用 户 表 ”, 其 结构 定义 为 用 户 名 \ 密 码 、 角 色 号 、 真 实 姓 名 、 性 别 、 
联系 方式 、 所 在 单位 。 设 置 用 户 名 为 主键 ,角色 号 为 外 键 。 

(4) 向 角色 表 中 输入 5 种 角色 : Jieshu、 Huanshu、 TEL 
Ruku、Baofei 和 Admin, 并 在 角色 名 和 角色 含义 字 
段 中 适当 说 明 每 种 角色 的 含义 。 

(5) 向 用 户 表 中 输入 3 一 10 名 用 户 ,并 适当 地 
设置 角色 。 

2. 设计 登录 程序 

(1) 新 建 项 目 LoginManual, 向 项 目 中 新 增 
Web 窗 体 ,命名 为 GzryLogin, 并 在 其 中 添加 一 个 
布局 表格 ,对 页 面 适当 布局 。 

(2) 适当 添加 必要 的 文字 信息 (如 “用 户 名 :”、 
“密码 :” 等 提示 性 文字 )。 向 窗 体 GzryLogin 中 增 
加 两 个 TextBox 控件 ,分 别 修改 其 ID 为 yhm 和 
psd, 然 后 修改 psd 的 TextMode 属性 为 Password。 
最 后 向 窗 体 中 增加 一 个 Button, 修改 其 ID 为 
btnLogin ,Text 值 为 “登录 ”。 

(3) 为 用 户 名 文本 框 yhm 和 密码 文本 框 psd 添加 必要 的 输入 验证 控件 ,要 求 用 户 必 须 
输入 用 户 名 和 密码 。 

(4) 向 项 目 中 添加 LINQ to SQL 类 ,命名 为 BOOKGL, 把 用 户 表 和 和 角色 表 添 加 到 
BOOKGL 的 数据 表 类 视图 中 ,并 设置 两 表 通 过 “角色 号 ”建立 关联 。 

(5) 为 按钮 ButtonLogin 的 Click 事件 和 Page_Load 事件 编写 程序 ,相应 的 代码 如 


10-27 利用 【服务 器 资源 管理 器 】 面 板 
新 建 SQL Server 数据 库 
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图 10-28 所 示 。 
i167 public partial class GzryLogin : Systen. Web.UI.Page 
| protected void Page Load(object sender, Eventhrgs e) 


if (Session["dlok"] == "OK") 
// 如 果 以 前 登录 过 ， 则 直接 进入 到 主 菜单 界面 
Response. Redirect ("Book]lain. aspx") ; 


下 
protected void btnLogin Click(object sender, Eventhrzs e) 


BookGLDataContext db = new BookGLDataContext () ; 
/1 获得 数据 库 的 DataContext 对 象 
Var res = fromr A 邮 . 用 
Where r, 用 户 名 = yhn. Text. Trin() select r; 
if (res.Count== 0 ) 7/ 如 果 用 户 冤 罕 用 户 雪 中 不 存在 ， 则 提示 用 
Response.Write("《Script>yalert (" 用 户 名 错误 ， 请 您 检查 ! 
else 
{ 


户 名 错误 。 
1 ') /script>"): 


Var rec = res.First () ; 取 首 条 记录 
证 (rec. 密 码 , Trin() 二 psd, Text. Trin0)// 寺 妇 玉生 棋 委 ， 则 提示 密 有 请 沁 
Response,Write("《Script>alert (" 密码 错误 ， 请 您 检查 ! ') ;</script》") ; 
else 
{ /如 果 全 部 正确 ， = 个 Session 变 里 ,分 别 表示 登录 状态 \ 用 户 名 、 角 色 
Session["dlok"] = "0| 
Session[" UserNane" 1 = 二 
Session["Role"] = rec. 和 角色: 
Response. Redirect ("BookMain. aspx") ; } 


图 10-28 自主 开发 登录 模块 的 源 程序 C# 代码 


注意 ; 在 此 模块 中 ,可 以 根据 大 多 数 用 户 的 在 线 时 间 长 度 设置 Session 的 生命 期 。 例 
如 ,制作 一 套 100 分 钟 考试 系统 ,就 可 以 设置 Session 生命 期 为 120 分 钟 。 只 须 在 定义 
Session 变量 前 增加 一 个 语句 “Session. Timeout 二 120;” 即 可 。 

3，Session 变量 对 各 程序 模块 的 控制 

上 述 登 录 模块 创建 了 3 个 Session 变量 ,分 别 用 于 在 用 户 的 会 话 期 内 标记 用 户 是 否 成 
功 登录 过 以 及 用 户 的 角色 和 用 户 名 。 

如 果 要 使 Session 变量 能 够 控制 窗 体 程序 的 执行 , 则 需 在 各 个 窗 体 的 Page_Load 事件 
中 添加 判定 语句 ,如 图 10-29 所 示 。 


18 ee void Page Load(object sender, Eventhres e) 
19 

20 if (Session[" dlok"]==null) 

21 Response. Redirect 和 全体 和 人 

22 if (Session["Role"]==nul 

23 Response. Redirect (" i 录 窗 体 的 文件 名") ; 

24 else 

25 if (Session["Role"].ToString()!=" 预 置 某 一 权限 " ) 

126 Response. Redirect ("登录 窗 体 的 文件 名 ") ; 

27 


10-29 利用 Session 变量 判断 用 户 是 否 有 权 执行 当前 模块 


4. 对 用 户 表 、 角 色 表 的 管理 

在 自主 开发 登录 模块 的 技术 中 ,用 户 表 和 角色 表 是 与 其 他 数据 表 完全 平等 的 数据 表 。 
因此 对 这 两 张 表 的 操作 可 使 用 与 其 他 数据 表 完全 相同 的 方式 。 也 就 是 说 ,向 用 户 表 中 增 
加 记录 就 是 创建 新 用 户 ,修改 用 户 表 的 角色 值 就 是 修改 用 户 的 权限 。 在 这 种 体系 中 , 完 
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全 可 以 把 用 户 信息 与 业务 数据 纳入 到 同一 数据 库 中 ,并 且 采 用 相同 的 数据 处 理 方式 进行 
管理 。 

需要 特别 指出 的 是 ,由 于 用 户 表 的 信息 关系 到 用 户 在 Web 项 目 中 的 使 用 权力 ,因此 
对 实施 用 户 表 编 辑 增加、 删除 功能 的 窗 体 ,要 进行 限制 ,规定 只 有 管理 员 用 户 才 有 权 使 
用 。 所 以 ,需要 在 这 种 窗 体 的 Page_Load 事件 中 添加 操作 可 行 性 的 判定 语句 ,如 图 10-30 
所 示 。 


protected void Page Load(object sender, Eventhres e) 


这 (Session["dlok"] == null ) // 未 登录 过 
Response. Redirect ("gzryLogin. aspx") : 


if (Session["Role"] == null) // 没 有 和 角色 什 
Response. Redirect(" gzryLogin. aspx") ; 

else if(Session["Role" ]. ToString () !="Adnin") // 不 是 管理 员 身 份 | 
Response. Redirect (" gzryLogin. aspx") ; 


图 10-30 超级 管理 员 专 用 页 面 中 包含 的 程序 运行 资格 判定 代码 


5. 注销 模块 的 实现 

用 户 访问 Web 应 用 系统 完毕 ,应 允许 用 户 注销 自己 的 登录 信息 ,退出 系统 。 在 以 
Session 控制 用 户 操作 权限 、 实 现 用 户 身份 认证 的 系统 中 , 杀 死 Session 即 可 实现 注销 用 户 
的 目的 。 因 此 ,实现 注销 功能 的 代码 如 图 10-31 和 图 10-32 所 示 。 


1 %@ Page Language="C#" AutoEventWireup="true”CodeBehind="Logout. aspx. cs” 
2 Inherits="Loginltanual. Logout” £33 

3 《IDOCTYPE html PUBLIC "~//W3C/ /DTD XHTIL 1.0 Transitional//EN" 

4 "http://www, wi. re Tht mL DT shen tmntmal. dtd"> 

5 日 《html xmlns=" ‘htt wy w3, org/ 1999/xhtnl” 

60 head runat="serVer 》 

了 《title> 无 标题 页 </titley> 

8 /head> 

9D body onload="alert (" 注销 成 功 " $3 this， location='GzryLogin. aspX' ;"> 
10 《form id="fornl”runat="serVer" > 

11 《div: 

12 < div)| 

13 《form> 

14 上 /body> 

15 上 《Ahtml> 


10-31 Logout. aspx 的 源 代码 


I4E nanespace TO0gITJTanuaT 

15 

16 public partial class Logout : System,Web,UI.Page 

17 { 

18 ee woid Page_Load(object sender, Eventhrgs e) 
19 

3 Session. hbandon() ; // 注 销 当前 用 户 的 Session 

21 ] 

2311 


图 10-32 ”Logout. aspx. cs 的 源 代码 


注意 ; 在 aspx 程序 中 , 当 Body 被 调 入 时 ,会 利用 JavaScript 语句 给 予 警 示 “ 注 销 成 
功 ”, 然 后 跳 转 到 GzryLogin. aspx 程序 。 而 其 C 井 代码 则 负责 在 Page_Load 事件 中 直接 执 
行 注销 当前 用 户 Session 实例 的 操作 : Session. Abandon() 。 
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候 考 是 


1. Web 应 用 系统 的 用 户 身份 验证 方式 主要 有 哪些 ?” 各 有 什么 特点 和 适应 性 ? 

2. Forms 身份 验证 的 主要 思路 是 什么 ?需要 哪些 要 素 的 支持 ? 

3. 什么 是 .NET 3.5 内 置 的 成 员 资格 管理 体系 ? 需要 哪个 数据 库 的 支撑 ? 

4. 什么 是 成 员 ? 什么 是 角色 ? 什么 是 访问 规则 ? 

5. 如 何 启动 .NET 3. 5 内 置 的 “网 站 管理 工具 ”? 在 此 “网 站 管理 工具 ”中 如 何 创建 新 用 
户 ,创建 角 色 和 创建 访问 规则 ? 

6. Login 控件 有 哪些 重要 属性 ? 如何 利 用 这 个 对 象 触发 LoginView 对 象 ? 

7. 什么 是 LoginView 对 象 ? LoginView 对 象 的 模板 有 哪些 ? 

8. 如 何 修改 用 户 的 对 应 密码 ? 如 何 使 用 ChangePassword 控件 ? 

9. 如 果 自 主 开发 登录 模块 ? 应 该 准备 哪些 数据 表 ? 数据 表 的 结构 是 什么 ? 

10. Session 变量 在 自主 开发 的 登录 模块 中 承担 什么 样 职责 ? 在 自主 开发 的 登录 模块 
中 ,如 何 保存 用 户 的 个 人 信息 ? 

11. 作为 填充 密码 的 文本 框 (TextBox) 控 件 ,应 该 具备 什么 类 型 的 TextMode? 

12. 在 Web 应 用 系统 的 其 他 模块 ( 非 登 录 模块 ) 中 ,应 如 何 利 用 Session 变量 控制 模块 
的 可 运行 性 ? 


仁 机 实 训 是 


一 、 利 用 内 置 的 成 员 资格 体系 构建 登录 系统 

新 建 项 目 TEST101 ,在 此 项 目 中 实践 以 .NET Framework 3.5 的 内 置 成 员 资格 体系 创 
建 登录 系统 ,完成 以 下 功能 。 

(1) 创建 用 户 登录 窗 体 Login, 在 Login 中 新 增 Login 控件 ,并 进行 配置 ,使 得 登录 成 功 
后 直接 调用 LoginSuccess 窗 体 。 

(2) 在 LoginSuccess 窗 体 中 增加 LoginView 控件 ,并 为 LoginView 控件 设置 不 同类 型 
用 户 ,不同 角色 用 户 的 显示 模板 。 

(3) 为 项 目 TEST101 添加 更 改 密码 ,新 用 户 注 册 .密码 重 置 的 窗 体 ,并 在 各 个 窗 体 中 放 
置 对 应 的 控件 。 
(4) 把 新 用 户 注册 、 密 码 重 置 窗 体 与 Login 控件 链接 起 来 ,使 无 法 登录 的 用 户 可 以 直接 
调用 “新 用 户 注 册 ” 和 “密码 重 置 " 窗 体 。 

(5) 在 已 登录 用 户 的 LoginView 模板 中 添加 “更 改 密码 ”按钮 ,并 把 更 改 密码 功能 链接 
到 “更 改 密码 ” 窗 体 上 。 

预览 项 目 TEST101 ,观察 其 效果 。 观 察 项 目 中 App_Data 文件 夹 下 的 数据 库 文件 。 

二 、 自 主 开发 登录 系统 

新 建 项 目 Test102, 在 此 项 目 中 创建 后 台数 据 库 并 自主 开发 登录 系统 。 为 此 需要 完成 
以 下 功能 。 
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(1) 利用 服务 器 资源 管理 器 ,创建 后 台数 据 库 , 并 建立 用 户 表 和 角色 表 , 输 入 若干 角色 
信息 和 用 户 信 息 。 

(2) 在 项 目 TEST102 中 新 增 登 录 窗 体 , 并 在 窗 体 中 增加 文本 框 * 用 户 名 ”和 “密码 ” 
控件 。 

(3) 根据 后 台数 据 库 的 用 户 表 进 行 用 户 名 和 密码 验证 。 对 于 通过 验证 的 用 户 ,利用 
Session 变量 记录 其 用 户 名 和 角色 。 

(4) 在 其 他 窗 体 的 Page_Load 方法 中 添加 判断 性 语句 ,对 于 Session 中 角色 值 不 满足 要 
求 的 用 户 , 则 直接 跳 转 到 登录 模块 ,不 再 继续 执行 本 窗 体 中 的 其 他 内 容 。 


学 习 要 点 

本 章 主要 学 习 ASP.NET 中 的 文件 管理 技术 。 要 求 了 解 如 何 获取 服务 器 的 驱动 器 信 
息 、 文 件 夹 信 息 和 文件 信息 ,掌握 文件 夹 创建 ,文件 读 取 与 写 入 的 关键 技术 ,掌握 文件 上 传 与 
下 载 的 主要 方法 。 本 章 重 点 关注 以 下 内 容 : 

。 获取 了 驱动 器 或 文件 夹 信息 的 关键 技术 。 

。 判定 文件 夹 (或 文件 ) 是 否 存 在 并 创建 文件 夹 (或 文件 ) 的 技术 。 

。 以 FileStream 和 StreamReader、StreamWriter 类 实现 文件 读 取 与 写 入 的 关键 技术 。 

。 把 文件 上 传 到 服务 器 上 指定 文件 夹 内 的 技术 。 

。 把 文件 上 传 到 数据 库 内 指定 字段 中 的 技术 。 

。 从 数据 库 内 读 取 文件 的 技术 。 


(11.1 ”驱动 句 与 文件 夹 管理 
A 


随 着 Internet 的 普及 ,因特网 中 网 络 磁盘 概念 的 提出 ,人 们 对 远程 的 文件 操作 也 提出 了 
一 定 的 需求 。 因 此 ,本 节 将 对 驱动 器 管理 和 文件 夹 管理 进行 简要 介绍 。 


11.1.1 获取 驱动 器 信息 


获取 驱动 器 信息 使 用 DriveInfo 类 ,利用 这 个 类 提供 的 方法 可 以 获取 驱动 器 的 详细 信息 。 
1. Drivelnfo 类 的 主要 方法 及 其 用 法 
DriveInfo 类 的 主要 属性 和 方法 如 表 11-1 所 示 。 


表 11-1 DriveInfo 类 的 主要 属性 和 方法 


属性 ,方法 名 称 说 明 
AvailableFreeSpace 获取 驱动 器 的 可 用 空间 量 。 此 命令 会 考虑 磁盘 的 配额 
DriveFormat 获取 驱动 器 文件 系统 的 格式 是 NTFS、 还 是 FAT32、FAT16 等 
DriveType 获取 驱动 器 的 类 型 
Name 获取 驱动 器 的 名 称 
RootDirectory 获取 驱动 器 的 根 文件 夹 , 返 回 值 为 文件 夹 型 量 
TotalFreeSpace 获取 驱动 器 的 空闲 空间 总 量 ,不 考虑 配额 问题 
TotalSize 获取 驱动 器 的 总 容量 


GetDrives() 方 法 获取 服务 器 的 所 有 逻辑 驱动 器 的 名 称 


第 11 章 文件 管理 


注意 : 除 GetDrives() 外 ,其 他 全 部 是 属性 ,返回 字符 串 型 结果 。GetDrives() 返 回 
DriveInfo 型 的 数组 。 使 用 DriveInfo 类 需要 引入 System. IO 命名 空间 。 

2. 获取 驱动 器 信息 的 示例 

新 建 Web 窗 体 DriverGL ,在 其 中 增加 一 个 Label 控件 ,命名 为 lblRes。 在 其 逻辑 代码 
部 分 进行 如 图 11-1 所 示 的 设计 , 即 可 获得 Web 服务 器 的 驱动 器 信息 。 


Ee: [using System. IO0; 

14- using System. Text ; 

15: 

16 日 namespace FileGL 

17 

18im public partial class Default : System. Web.UI.Page 

19 { 

20i9 protected void Page_Load(object sender, Eventhrgs e) 

21 { 

22 if (!IsPostBack) 

23 { 

24 StringBuilder strb = new StringBuilder():; 

25 DriveInfo []drvs = DriveIrfo.GetDrives () ; 

26 foreach (DriveInfo drv in drvs) 

27 { 

28 if (drv. IsReady) 

29 [ 

30 strb. Append(" 将 ”+ drv.Namet+" <br>"); 

31 strb, Append(” 驱动 器 类 型 : ”+ drv， DriveType + "<br>" ); 

32 strb. Append(" 最 动 归 关 娄 生 系 区 "+ drv, DriveType +" br ; 
39 strb. Append(” 驱动 器 大 小 : ”+ drv. TotalSize + "Cbr>"); 

34 strb. Append(” 驱动 器 可 用 空间 : ”+ drv. AvailableFreeSpace + "<br>"); 
35 strb. Append(” 孤 动 器 总 可 用 空间 : ”+ drv. TotalFreeSpace + "br>"); 
36 } 

37 } lblRes. Text = strb, ToString () ; 

38 

39| 

40ir } 

4 } 

42 


图 11-1 “获得 驱动 器 信息 ”程序 的 C# 源 代 码 


注意 ; 为 了 使 用 DrivelInfo 和 StringBuilder 类 ,本 例 中 另外 引入 了 两 个 名 称 空间 ; 
System. IO 和 System. Text。 
程序 的 运行 效果 如 图 11-2 所 示 。 


Ge- FT 
将 N EV 《大 和，IROD 和 由 
| 会 "四 "局 赴 > ” 


驱动 器 名 称 ，C3 
驱动 器 类 型 ，Fixed 
驱动 器 的 文件 系统 ,Fixed 
驱动 器 大 小 :50009669632 
驱动 器 可 用 空间 : 28807213056 
驱动 器 总 可 用 空间 ，28807213056 
驱动 器 名 称 ，Di 
驱动 器 类 型 ，Fixed 
驱动 器 的 文件 系统 ，Fixed 
驱动 器 大 小 ，45008699392 
驱动 器 可 用 空间 : 37843349504 
驱动 器 总 可 用 空间 ，37843349504 


11-2 “获得 驱动 器 信息 ”程序 的 运行 效果 图 
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11.1.2 文件 夹 管理 


对 文件 夹 的 管理 , .NET 3. 5 提供 了 两 个 类 : Directory 和 DirectoryInfo, 这 两 个 类 的 用 
法 大 同 小 异 ,只 是 Directory 类 中 的 所 有 属性 和 方法 都 是 静态 的 ,需要 对 每 一 步 操 作 进 行 安 
全 性 检查 ,而 DirectoryInfo 类 中 属性 和 方法 都 是 隶属 于 对 象 内 部 ,只 在 对 DirectoryInfo 实 
例 化 的 时 候 进行 一 次 总 的 安全 性 检查 。 因 此 对 于 仅 执 行 一 个 操作 的 文件 夹 处 理 ,建议 使 用 
Directory 类 ,而 集中 的 、 多 样 化 的 文件 夹 操作 , 则 建议 使 用 DirectoryInfo 类 。 

1. 文件 夹 管理 的 主要 方法 

1) 主要 方法 

对 文件 夹 的 管理 以 方法 为 主 , 表 11-2 列 出 常见 的 方法 及 其 用 法 。 


表 11-2 Directory 和 DirectoryInfo 类 的 主要 方法 及 其 用 法 


方法 名 用 途 隶 属 于 
CreateDirectory( 文 件 夹 信息 ) 创建 指定 路 径 中 的 文件 夹 Directory 
Delete( 文 件 夹 信息 ) 删除 指定 的 文件 夹 Directory/DirectoryInfo 
Exists( 文 件 夹 信息 ) 判断 文件 夹 是 否 存在 Directory 
GetCurrentDirectory() 获取 应 用 程序 的 当前 文件 夹 Directory 
GetDirectories( 文 件 夹 信息 ) 获取 指定 文件 夹 下 的 所 有 直属 子 文件 夹 。 Directory/DirectoryInfo 
GetFiles( 文 件 夹 信 息 ) 获取 指定 文件 夹 下 的 所 有 直属 文件 Directory/DirectoryInfo 
GetFileSystemEntries( 文 件 夹 信 息 ) 返回 指定 文件 夹 下 的 所 有 文件 夹 . 文 Directory 
件 的 名 称 集合 
Move( 源 文件 夹 ,目标 文件 夹 ) 将 文件 夹 及 其 内 容 移 动 到 新 的 位 置 。 Directory 
Create() 创建 文件 夹 DirectoryInfo 
CreateSubDirectory( 基 于 当前 对 象 的 ”在 指定 位 置 创建 子 文件 夹 DirectoryInfo 
文件 夹 标志 ) 
MoveTo( 新 位 置 ) 将 当前 文件 夹 移动 到 新 位 置 DirectoryInfo 
2) 重要 说 明 


由 于 Directory 是 静态 类 ,对 隶属 于 Directory 的 方法 ,必须 使 用 “Directory. 方法 名 ( 参 
数 )” 进 行 调用 ,而 且 其 参数 通常 为 完整 路 径 。 而 DirectoryInfo 是 对 象 类 ,要 使 用 其 中 的 方 
法 必须 先 初始 化 一 个 对 象 ,然后 利用 “对 象 名 . 方法 名 (参数 )” 的 方式 调用 ,而 且 其 参数 一 般 
是 基于 所 属 对 象 的 相对 路 径 , 或 者 干脆 没有 参数 。 

例如 ,要 删除 字符 串 path 所 指示 的 子 文件 夹 , 可 以 分 别 使 用 以 下 几 种 方法 。 

(1) 如 果 使 用 Directory 类 ,其 命令 为 ; 


Directory. Delete(path); // 直 接 删除 此 文件 夹 
(2) 如 果 使 用 DirectoryInfo 类 ,其 命令 为 两 个 : 


DirectoryInfo dd = new DirectoryInfo( path) ; // 获 取 子 文件 夹 对 象 
dd. Delete(); // 子 文件 夹 dd 被 删除 
2. 文件 夹 及 其 路 径 表示 
在 文件 夹 和 文件 管理 中 ,文件 路 径 描述 是 管理 的 关键 ,错误 的 路 径 信 息 将 导致 操作 失 
败 。 因 此 对 文件 夹 的 管理 ,采取 了 专门 的 技术 进行 文件 夹 路 径 描述 。 
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1) 路 径 分 隔 符 的 问题 

由 于 在 C# 中 ,“\" 充 当 转 义 字符 ,所 以 需要 在 所 有 真正 的 “\” 符 号 前 添加 “\”, 以 保证 
C# 语 言 编译 器 的 正确 解析 。 比 如 描述 C 盘 根 文件 夹 下 的 文件 夹 ma 和 ma 中 的 文件 
al. txt, 就 需要 使 用 如 下 格式 “C:\\ma” 和 *C:\\ma\\al. txt”。 

上 述 描述 方式 对 于 计算 机 程序 员 来 讲 也许 不 是 什么 难事 ,但 对 普通 用 户 来 讲 就 显得 很 
烦琐 了 。 为 此 ,C# 专 门 提供 了 一 个 取消 转 义 功能 的 符号 “@”。 如 果 在 一 个 字符 串 前 面 增 
加 了 “@” 符 号 ,就 表示 此 字符 串 取 消 使 用 转 义 符 “\”, 凡 是 在 字符 序列 中 出 现 的 “\" 都 是 真正 
的 “\”。 那 么 对 于 上 述 的 两 个 文件 路 径 , 就 可 以 书写 为 “@C:\ma” 和 “@C:\ma\al, txt”。 

2) 获取 绝对 路 径 的 技术 

在 Web 系统 中 ,常常 需要 获取 Web 应 用 系统 的 绝对 路 径 , 以 便 实 现 各 种 文件 操作 。 目 
前 ,获得 Web 应 用 程序 的 绝对 路 径 主 要 有 两 种 方式 。 

。 方法 1: 利用 “Request. PhysicalApplicationPath” 获 得 当前 的 Web 应 用 程序 的 绝对 

路 径 。 
。 方 法 2: 利用 “Server. MapPath( 指 定 虚拟 目录 名 或 应 用 程序 下 的 文件 夹 名 称 )” 获 得 
该 目录 或 文件 夹 的 绝对 路 径 。 

3) Path 类 对 路 径 管理 的 支持 

为 了 支持 路 径 管理 , .NET 专门 提供 了 一 个 Path 类 ,其 中 的 方法 专门 用 于 支持 路 径 管 
理 。 其 主要 的 方法 如 表 11-3 所 示 。 


表 11-3 Path 类 的 主要 方法 


方 ” 法 说 ”有明 
Combine( 字 符 串 1, 字 符 串 2) 把 两 个 路 径 字 符 串 合并 
GetDirectoryName( 路 径 ) 获取 指定 路 径 的 文件 夹 名 称 信息 
GetExtension( 路 径 ) 获取 指定 路 径 的 文件 夹 的 扩展 名 信息 
GetFileName( 路 径 ) 获取 指定 路 径 中 文件 名 与 扩展 名 信息 
GetFullPath( 路 径 ) 获取 指定 路 径 的 完整 路 径 
GetRandomFileName() 获取 随机 的 文件 夹 名 或 文件 名 


11.1.3 文件 夹 管 理 示 例 


1. 输出 指定 文件 夹 的 下 级 结构 

1) 案例 要 求 

设计 如 图 11-3 所 示 的 程序 , 当 在 文本 框 中 输入 一 个 文件 夹 的 名 称 后 ,系统 将 输出 该 文 
件 夹 中 所 有 文件 及 其 全 体 子 文件 夹 的 文件 夹 名 称 。 

2) 设计 思路 

由 于 文件 系统 本 身 是 一 种 树 状 结构 ,因此 可 以 使 用 树 遍 历 的 方式 输出 指定 文件 夹 的 整 
个 体系 。 而 树 的 遍历 是 一 种 递归 遍历 。 因 此 本 例 也 借用 递归 遍历 的 方式 。 

3) 设计 流程 

新 建 窗 体 DirStruct. aspx, 在 其 中 加 入 一 个 TextBox., 一 个 Label 和 一 个 Button ,并 按 
图 11-3 适当 排列 其 位 置 ,添加 必要 的 文字 说 明 。 设 置 三 个 控件 的 名 称 依次 为 txtDirName、 
lblRes、btnRes, 则 相应 的 程序 代码 如 图 11-4 所 示 。 
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文件 夹 管理 示意 程序 
请 输入 一 个 文件 夹 各 : GiBook 
EE 二 到 


文件 参考 格式 doc 


文件 ，bskladoc 


11-3 “获得 文件 夹 和 文件 信息 ”程序 的 运行 效果 图 


nse FileGL 

17i 

18 加 public partial class DirStruct : System. Web.UI.Page 

19! { 

20 间 protected void Page_Load(object sender，Eventargs e) 

21: 

22 I 

23 有 public static void dirDisp(DirectoryInfo d, StrineBuilder strb, int xx) 
24 {// 自 定义 递归 函数 ， 用 于 显示 并 处 理 文件 夹 系统 

25: V/strb 用 于 存储 检索 结果 ，xx 用 于 标记 文件 来 的 层次 

26 

27| String str =""; // 产 生 所 需 的 空格 ， 以 表达 文件 夹 所 述 层次 
28 for (int i = 0; i < 2rxx; i+tt) str = str + "hnbsp;"; 

29 

30 FileInfo[] fns = d.GetFiles(); 

31 foreach (FileInfo fn in fns) 

32 

33i strb. Append (str); zf/ 加 入 若干 个 空格 

341 strb.Append(" 文件"+fn. Namet+" <br>"); /7 获取 文件 名 信息 
35 ] 

36 

37 DirectoryInfo []dns = dGetDirectories () ; 

38 ota {DirectoryInfo dn in dns) 

39 

40 strb. Append {str); // 加 入 若干 个 空格 

411 strb, 如 pend(" 文 件 来 ”+ dn.Name + "<br>") ; /7 获取 文件 夹 名 称 信息 
42 dirDisp(dn，strb，xx + 1); /递归 调用 ， 处 理 其 子 文件 来 
43 

44 填 

45 加 protected void btnRes_Click (object sender, Eventhrgs e) 

46: { 

47 String path = txtDirName. Text. Trim(); 

48 if (Directory. Exists (path)) { 

49 StringBuilder strb=new StringBuilder () ; 

50 DirectoryInfo dd=new DirectoryInfo(path) ; 

51 dirDisp(dd，strb，0) : 

52 lblRes, Text=strb, ToString () ; 

53: 

543 

55 else lblRes. Text="<script>alert ("文件 夹 不 存在 ! ') ;</script>"; 
56i:r 

5 } 

58 江 】} 


图 11-4 “获得 文件 夹 和 文件 信息 ”程序 的 C# 源 代码 
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4) 补充 说 明 

对 此 程序 当然 可 以 添加 更 多 的 信息 ,例如 ,把 文件 的 创建 日 期 ,文件 的 大 小 等 信息 显示 
出 来 ,还 可 以 把 文件 夹 结 点 添加 到 TreeView 控件 中 ,以 树 状 结构 呈现 出 文件 的 结构 。 

2. 在 指定 文件 夹 中 创建 新 文件 夹 

1) 案例 要 求 

设计 如 图 11-5 所 示 的 程序 ,首先 在 一 个 文本 框 中 指定 需要 建立 子 文件 夹 的 位 置 ,然后 
说 明 要 建立 的 子 文件 夹 的 名 称 。 当 单 击 【执行 创建 3 按钮 时 ,将 在 指定 位 置 创建 子 文件 夹 。 


OO le en. -[als [x||P szes 
文人 四 吉本 上 瑟 W 《大 KW IROD 和 是 


EL 食 " 目 "口交 > 
建立 子 文件 夹 
请 在 Hct1web 位 置 创建 子 文 件 夫 ，md10 


11-5 “在 指定 位 置 创 建 子 文件 夹 "程序 的 运行 效果 图 


2) 设计 流程 

新 建 窗 体 MkDir. aspx, 在 其 中 加 入 两 个 TextBox 和 一 个 Button, 并 适当 排列 其 位 置 ， 
添加 必要 的 文字 说 明 , 如 图 11-5 所 示 。 设 置 三 个 控件 的 名 称 依次 为 txtPath、txtNewDir、 
btnMkdir。 要 实现 创建 文件 夹 的 功能 ,相应 的 程序 代码 如 图 11-6 所 示 。 


13¥ using Systen. 10; 

14 

15 昌 namespace FileGL 

16| { 

17im public partial class MakeDir : System. Web.UI.Page 

18 { 

19im protected void Page Load(object sender, Eventhras e) 

20 { 

21 } 

22: 

23i9 protected void btnllkdir_Click (object sender, Eventhres e) 

24 { 

25 String path = txtPath. Text. Trin() : 

26: String dirNane = txtNewDir. Text. Trinm(); 

27 

28 证 (Directory.Exists (path)) // 判 断 建文 件 夹 的 位 置 是 否 正 确 

29| { 

30 DirectoryInfo dir = new DirectoryInfo(path) ; 

31 String newPath=Path.Combine (path, dirName); 

32 证 (Directory, Exists(newPath)) { // 判 断 新 文件 来 是 否 存在 
33: Response. Write("<script>alert(' 新 文件 来 已 存在 ! ') ;</script》"); 
34 } 

汉 else { 

36: dir.CreateSubdirectory (dirName) ;  // 创 建新 文件 夫 

37 // 或 者 使 用 命令 Directory. CreateDirectory (nevPath) ; 
38: if (Directory.Exists (newPath)) _ 

39 Response.Write("《script>alert (新 文件 夹 建立 成 功 ! ');《/script》"); 
40 】 

41 } 

42 else S Co 
43 Response.Write("《script>alert (" 指定 位 置 不 存在 ， 无 法 建立 ! ') ;</script>") ; 
dd ! 

45 ! 

46:-} 


图 11-6 “在 指定 位 置 创 建 子 文件 夹 程序 ”的 C# 源 代码 
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阅读 程序 时 ,注意 Directory 方法 和 DirectoryInfo 方法 的 区 别 , 体 会 其 中 的 含义 。 


(1,2 文件 处 理 


读 写 文件 是 Web 应 用 程序 设计 中 的 一 个 常见 操作 。 在 当前 的 计算 机 与 网 络 技 术 中 ,人 
们 把 对 文件 的 处 理 和 对 其 他 I/O 设备 输入 与 输出 信息 的 处 理 等 同 看 待 ,采用 同样 的 技术 进 
行 管理 。 目 前 ,数据 流 是 输入 输出 信息 处 理 的 通用 概念 。 即 对 于 CPU 来 讲 , 不 论 是 文件 、 
内 存 、 普 通 I/O 设备 ,还 是 网 络 端口 ,都 是 在 提供 数据 流 的 输入 与 输出 。 因 此 Stream 类 及 其 
方法 应 运 而 生 , 它 们 在 .NET 开发 技术 和 Java 开发 技术 中 被 广泛 地 应 用 于 文件 管理 、 网 络 
信息 和 1/O 信息 处 理 。 


11.2.1 基于 Stream 的 文件 处 理 


在 .NET 框架 中 ,Stream 类 是 一 个 从 I/O 概念 之 上 抽象 出 来 的 基础 性 的 类 (class) , 它 
可 以 泛 指 一 切 字 节 流 ,其 基本 操作 单位 是 字 节 。 而 在 具体 的 应 用 中 ,Stream 总 是 要 与 具体 
的 设备 结合 在 一 起 使 用 的 : 与 磁盘 操作 结合 构成 了 FileStream, 与 网 络 的 输入 输出 结合 则 
构成 NetworkStream, 与 内 存 管理 结合 则 形成 了 MemoryStream。 因 此 Stream 本 身 是 一 个 
抽象 类 , 它 不 能 直接 生成 对 象 。FileStream 是 其 关于 文件 处 理 的 派生 类 。 

1. 基于 FileStream 实施 文件 处 理 的 流程 

首先 ,需要 以 字符 串 形式 形成 完整 的 文件 路 径 。 

其 次 ,建立 FileStream 流 对 象 , 在 建立 对 象 时 指明 流 对 象 的 类 型 。 

第 三 ,在 内 存 中 建立 字 节 数组 ,用 于 实现 与 FileStream 的 交互 。 

第 四 ,执行 读 写 操作 。 

最 后 ,关闭 FileStream 对 象 。 

2. FileStream 流 对 象 

1) Server. MapPath(" 文 件 标 识 ") 

Server. MapPath 是 一 个 Web 服务 器 的 方法 ,用 于 获得 指定 文件 的 完整 绝对 路 径 。 

注意 : 此 处 的 文件 标识 使 用 相对 路 径 , 以 当前 文件 夹 为 标准 。 如 果 要 访问 的 文件 处 于 
当前 文件 夹 的 子 文件 夹 中 ,那么 在 文件 标识 中 应 以 “ 子 文件 夹 名 /文件 名 ”的 格式 描述 。 

2) 创建 FileStream 流 对 象 

创建 FileStream 流 对 象 的 最 常见 格式 如 下 : 


FileStream 对 象 名 = new FileStream( 完 整 文件 标识 ,文件 模式 ) ; 
另外 ,还 有 一 种 设置 更 为 仔细 的 形式 ,使 用 率 也 很 高 : 
FileStream 对 象 名 = new FileStream( 完 整 文件 标识 ,文件 模式 , 存 取 方式 ,共享 方式 ); 


3) 文件 流 模式 

在 FileStream 流 技 术 中 ,人 们 以 文件 模式 设置 文件 流 的 打开 或 使 用 方式 。 主 要 有 以 下 
几 种 常见 的 形式 ， 

。 FileMode. Open 表示 打开 文件 。 若 文件 不 存在 ,系统 将 报错 。 
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。 FileMode. Create 表示 将 建立 一 个 新 文件 。 如 果 已 经 存在 同名 文件 ,原文 件 将 被 覆盖 。 

。 FileMode. Append 表示 以 添加 方式 打开 文件 。 如 果 文 件 不 存在 ,系统 会 自动 创建 此 
文件 ; 

4) 文件 存 取 方 式 

FileAccess 常量 用 于 确定 FileStream 对 象 访问 文件 的 方式 。 主 要 有 以 下 几 种 常见 形式 ， 

。 FileAccess. Read 表示 流 对 象 可 读 。 

。 FileAccess. Write 表示 流 对 象 可 写 。 

。 FileAccess. ReadWrite 表示 流 对 象 可 读 也 可 写 。 默 认为 ReadWrite 方式 。 

5) 文件 共享 方式 

FileShare 常量 用 于 确定 FileStream 是 否 可 被 共享 。 主 要 有 以 下 几 种 常见 形式 : 

。 FileShare. None 表示 不 允许 共享 文件 ,默认 为 None 方式。 

。 其 他 值 Read、Write、ReadWrite、Delete 依次 表示 可 共享 读 、 可 共享 写 .可 共享 读 写 、 
可 删除 。 

3. FileStream 类 的 常用 属性 和 方法 

1) 常用 属性 

FileStream 类 的 主要 属性 及 其 用 法 见 表 11-4。 


表 11-4 FileStream 类 的 主要 属性 及 其 用 法 


属 性 说 ”有明 
CanRead 逻辑 值 ,用 于 判断 当前 流 是 否 支持 读 取 
CanWrite 逻辑 值 ,用 于 判断 当前 流 是 否 支持 写 人 
Length 获取 文件 流 对 应 的 文件 的 大 小 (以 字 节 为 单位 ) 
ReadTimeOnut 设置 或 者 获取 读 超时 的 时 间 值 ,以 毫秒 为 单位 
WriteTimeOut 设置 或 者 获取 写 超时 的 时 间 值 ,以 毫秒 为 单位 
2) 常用 的 方法 


FileStream 类 的 主要 方法 及 其 用 法 见 表 11-5。 
表 11-5 FileStream 类 的 主要 方法 及 其 用 法 
邦 法 说 上 明 


Read( 字 节 型 数组 名 ,位 置 ,长 度 ) ”从 文件 流 中 读 取 指定 长 度 的 数据 放 到 字 节 型 数组 的 指定 位 置 处 
ReadByte() 从 文件 流 中 读 取 一 个 字 节 
Write( 字 节 型 数组 名 ,位 置 ,长 度 ) ”把 字 节 型 数组 中 从 指定 位 置 开 始 的 、 指 定 长 度 的 数据 存储 到 文件 


流 中 
Flush() 清空 文件 流 缓冲 区 中 的 数据 ,常常 用 于 写 盘 操作 后 
Close() 关闭 文件 流 ,回收 文件 流 占 用 的 内 存 空间 
BeginRead() 启动 异步 读 取 
EndRead() 关闭 异步 读 取 
BeginWrite() 启动 异步 写 人 


EndWrite() 关闭 异步 写 人 
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No 动态 网 站 设计 
4. 实例 : 利用 文件 字 节 流 实现 文件 复制 
1) 案例 要 求 
设计 如 图 11-7 所 示 的 文件 复制 程序 。 利 用 两 个 文本 框 获取 源 文件 名 和 目标 文件 名 , 然 
后 单 击 【文件 复制 按钮 ,对 源 文件 实施 复制 操作 。 


训 4 关 。 乱 天 EX | 从 ~“ 园 " 己 昌 ”>” 
利用 FileStream 实 现 文件 复制 
源 文件 名 ，web conig 目标 文件 名 ，ma4txt 
EEO 


图 11-7 “利用 FileStream 类 实现 文件 复制 程序 ”的 运行 效果 图 


2) 设计 流程 

新 建 窗 体 FileStreamCopy. aspx, 在 其 中 加 入 两 个 TextBox 和 一 个 Button ,并 适当 排列 
其 位 置 ,并 添加 必要 的 文字 说 明 , 如 图 11-7 所 示 。 然 后 ,设置 三 个 控件 的 名 称 依次 为 
txtSfn、txtDFn、btnCopy。 则 相应 的 程序 代码 如 图 11-8 所 示 。 


25 押 protected void btnCopy_C1ick(object sender, Eventhrgs e) 

26| { 

27 String sfn = txSFn. Text.Trim(); ”// 获 取 源 文件 名 

28 String dfn = txtDFn, Text.Trinf) /1 获取 目标 文件 名 

29 String path = Server. MapPath(""); // 获 取 应 用 程序 的 绝对 路 径 

30 sfn = Path.Combine (path，sfn) ;  // 拼 合 源 文 件 与 路 径 

31 dfn = Path, Conmbine (path, dfn) 和 

32 if (IFile, Exists (sfn)) { /1 判定 产 文 件 是 否 存 在 

33 Response. Write("《<Script>alert(' 源 文件 不 存在 ! '); 《Script>"); 
34 return:} 

35 try 

36 ' 

37 FileStream sfs = new FileStreantsfn, FileMode. Open) ; 

38 f/f 以 读 取 方式 获得 源 数据 流 

39 FileStrean dfs = new FileStrean(dfn, FileNMode. Append):; 

40 /以 添加 方式 获得 目标 数据 流 

dl byte[] data = new byte[sfs.Length] ; 

d2 int counter = (int) sfs.Length: // 获 取 源 文件 的 大 小 

43 sfs.Read(data, 0, counter). /1 读 取 整个 源 文 件 

dd dfs. Writeldata, 0, counter); ‘人 

45 sfs.Close(); dfs.Flush(); dfs.Close() 

d6 Response. Write("<Script>alert ("文件 被 成 功 复 制 ! ') ;</Script》") ; 
47 } 

48 catch (Exception eee) { Response. Write(eee.StackTrace.ToString ()); } 
49 上 | 1} 


11-8 “利用 FileStream 类 实现 文件 复制 "程序 的 C# 源 代 码 


3) 补充 说 明 

(1) 本 程序 需要 引用 命名 空间 System. IO。 

(2) 出 于 安全 性 的 原因 ,在 默认 设置 下 , .NET 程序 只 允许 读 取 应 用 程序 文件 夹 中 的 文 
件 , 不 允许 操作 应 用 项 目 范围 以 外 的 文件 夹 和 文件 。 

(3) 如 果 源 文件 很 大 , 则 需要 定义 一 个 较 小 的 字 节 数组 ,利用 循环 语句 控制 读 取 和 写 
入 ,以 免 因 源 文件 过 大 导致 系统 崩溃 ; 或 者 逐个 字 节 读 取 并 逐个 字 节 写 信 。 
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5. 实例 : 利用 文件 字 节 流 实现 输入 内 容 的 存盘 

1) 案例 要 求 

设计 如 图 11-9 所 示 的 程序 ,要 求 把 文本 区 域 中 输入 的 内 容 利 用 FileStream 类 的 方法 存 
储 到 文本 框 指定 名 称 的 文件 中 。 


司 hapyloaalh- |B| t+ |X ||P Eee ER 
富 届 天 着 天 [li 全 7 a 
请 输入 数据 ， 


我 是 一 个 优秀 的 人 民 教师 。Good Morning! 


存储 文件 名 |ma89.ba [EE 


图 11-9 “把 输入 的 信息 保存 到 指定 文件 ”程序 的 运行 效果 图 


2) 设计 流程 

新 建 窗 体 FileStreamSave. aspx, 在 其 中 加 入 两 个 TextBox 和 一 个 Button ,并 适当 排列 
其 位 置 ,并 添加 必要 的 文字 说 明 , 如 图 11-9 所 示 。 设 置 三 个 控件 的 名 称 依次 为 txtData、 
txtDfn、btnSave, 然 后 设置 txtData 文本 框 的 TextMode 属性 为 MultiLine。 最 终 , btnSave 
的 Click 事件 对 应 的 程序 代码 如 图 11-10 所 示 。 


3 te void btnSave_Click (object sender, Eventhres e) 

26: 

好 String dfn = txtDfn. Text, Trin(); /7 获取 目标 文件 名 

28 String tdata = txtData. Text. Trim() ; 

29 String path = Server.NapPath(""); // 获 取 应 用 程序 的 绝对 路 径 

30 dfn = Path. Combine (path, dfn) ; // 拼 合 目标 文件 名 与 路 径 

31 try 

32 { 

33 FileStream dfs = new "PileStrean (dfn, FileMode. Append) ; 

34 // 以 添加 方式 获得 目标 数据 流 

35 byte[] data = Encoding. UTFS, GetBytes (tdata) : 

36 int counter = (int)data.Length; // 获 取 字 节 数组 的 大 小 

37 dfs.Write(data，0，counter); ” // 写 入 目标 文件 

38 dfs. Flush(); dfs.Close(); 

39 Response, Write("<Script>alert(' 文件 写 入 成 功 ! ');《/Script>》"); 
40 } 

41 catch (Exception eee) { Response.Write(eee. StackTrace.ToString()); } 
42 站 } 


图 11-10 “把 输入 的 信息 保存 到 指定 文件 ”程序 的 C# 源 代码 


注意 : 本 程序 需要 引用 命名 空间 System. IO 和 命名 空间 System. Text。 

6. 关于 文件 字 节 流 的 补充 说 明 

由 于 FileStream 采用 字 节 流 的 方式 完成 文件 操作 。 因 此 其 处 理 信息 的 基本 单位 是 字 
节 , 常 用 的 文件 类 型 是 字 节 数组 (byte[]) 形 式 , 而 常用 的 String 则 是 字符 串 的 形式 。 为 此 ， 
需要 利用 System. Text 命名 空间 中 的 Encoding 类 实现 数据 的 编码 转换 。 
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利用 Encoding. UTF8. GetBytes( 字 符 串 类 型 ) 可 以 把 字符 串 类 型 转化 为 字 节 类 型 数 
组 ,其 姊妹 方法 Encoding. ASCIIL GetBytes( 字 符 串 类 型 ) 可 以 把 纯 英 文 的 字符 串 转 化 为 字 
节 数 组 ,所 以 Encoding. UTF8. GetBytes( 字 符 串 类 型 ) 具 有 更 强 的 适应 性 。 

而 利用 Encoding. UTF8. GetString (bytes) 可 以 把 一 个 字 节 型 数组 转化 为 字符 串 
CString) 类型。 


11.2.2 基于 Reader 和 Writer 的 文件 处 理 


1, Reader 类 与 Writer 类 简介 

正如 11.2. 1 节 指 出 的 ,FileStream 是 基于 字 节 流 的 类 ,与 人 们 习惯 使 用 的 字符 型 量 有 
差异 ,需要 专门 编码 完成 这 种 编码 之 间 的 转换 。 为 此 , .NET 在 Stream 的 基础 上 封装 了 针 
对 字符 的 Reader 类 和 Writer 类 ,结合 面向 文本 型 文件 读 写 的 TextReader 和 TextWriter 抽 
象 类 , 形成 了 StreamReader 和 StreamWriter 类 ,并 进而 出 现 了 面向 二 进 制 文件 的 
BinaryReader 和 BinaryWriter 类 。 

由 于 TextReader 和 TextWriter 是 抽象 类 ,不 能 直接 生成 对 象 ,所 以 如 果 需 要 使 用 
TextReader 和 TextWriter ,可 由 相应 的 StreamReader 和 StreamWriter 对 象 来 执行 处 理 过 程 。 

2. TextReader 类 与 TextWriter 类 的 主要 方法 

1) TextReader 类 的 主要 方法 

TextReader 类 的 主要 方法 及 其 用 法 见 表 11-6。 


表 11-6 TextReader 类 的 主要 方法 及 其 用 法 


方 法 说 有明 
Read() 从 TextReader 流 中 读 取 一 个 字符 ,把 结果 作为 字符 返回 
ReadLine() 从 TextReader 流 中 读 取 一 行 字符 ,把 结果 作为 字符 串 返回 
ReadToEnd() 从 当前 TextReader 流 中 读 取 字 符 直到 文件 结束 ,并 把 读 取 结 果 作 为 
一 个 字符 串 返 回 
Close() 关闭 文件 流 , 回 收文 件 流 占用 的 内 存 空 间 , 释 放 资 源 


2) TextWriter 类 的 主要 方法 
TextWriter 类 的 主要 方法 及 其 用 法 见 表 11-7。 
表 11-7 TextWriter 类 的 主要 方法 及 其 用 法 


六 :法 说 明 
Write( 数 据 ) 将 给 定 的 一 个 数据 写 人 文本 数据 流 ,不 加 换行 符 
WriteLine( 数 据 ) 将 给 定 的 一 个 数据 写 人 文本 数据 流 ,并 加 一 个 换行 符 
Flush() 清空 当前 写 人 文本 流 的 缓存 
Close() 关闭 文件 流 , 回 收文 件 流 占 用 的 内 存 空间 ,释放 资源 


3. TextReader 类 与 TextWriter 类 应 用 示例 

1) 案例 要 求 

设计 如 图 11-11 所 示 的 程序 ,要 求 把 文本 区 域 中 输入 的 内 容 利 用 TextReader 技术 存储 
到 文本 框 指定 名 称 的 文件 中 ,然后 以 [清空 区 域 按 钮 清除 文本 区 中 的 数据 后 , 单 击 【 读 取 数 
据 ] 按 钮 ,利用 TextWriter 把 数据 从 指定 的 文件 中 读 取出 来 。 


OO [a re/ [a 


诺 和 天 | 名 天 i 页 


存储 文件 名 


11-11 “利用 TextWriter 类 保存 输入 信息 ”程序 的 运行 效果 图 


2) 设计 方法 


EST 


Er 
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新 建 窗 体 FileText. aspx, 在 其 中 加 入 两 个 TextBox 和 三 个 Button ,并 适当 排列 其 位 
置 ,添加 必要 的 文字 说 明 , 如 图 11-11 所 示 。 设 置 两 个 文本 框 控件 的 名 称 依次 为 txtData、 
txtDfn, 三 个 按钮 控件 的 名 字 为 btnSave、btnCls 和 btnRead, 然 后 设置 txtData 文本 框 的 


TextMode 属性 为 MultiLine。 


相关 按钮 的 Click 事件 对 应 的 程序 代码 如 图 11-12 所 示 。 
注意 ; 本 示例 需要 另外 引入 System. IO 和 System. Text 命名 空间 。 


4. 基于 BinaryReader 和 BinaryWriter 的 技术 
除了 对 文本 格式 实施 处 理 的 TextReader 和 TextWriter 对 象 , .NET 还 专门 提供 了 面 
向 二 进 制 数据 的 读 写 类 BinaryReader 和 BinaryW riter。 
在 使 用 BinaryReader 和 BinaryWriter 操作 数据 时 ,各 种 数据 将 以 原始 的 二 进 制 的 形式 
被 写 人 到 文件 中 ,因此 为 保证 数据 读 取 的 正确 性 ,必须 使 用 对 应 的 数据 类 型 把 数据 读 取出 
来 。 数 据 类 型 的 使 用 错误 和 读 写 过 程 的 不 对 称 ,都 会 导致 乱码 数据 的 发 生 。 也 就 是 说 ,如 果 
以 BinaryWriter 方 式 向 文件 中 写 人 了 一 个 字符 串 .2 个 int 型 量 、1 个 bool 型 量 和 1 个 浮 点 
型 量 , 那 么 在 读 取 时 也 必须 使 用 相应 的 语句 。 假 设 BinaryReader 对 象 为 br, 那 么 读 取 数据 


的 语句 对 应 是 ， 


String ss = br. ReadString(); int xl = br.ReadInt32(); int x2 = br. ReadInt32(); 
bool bl = br. ReadBoolean( ); float fl = br.ReadSingle( ) ; 
由 于 采用 这 种 类 型 存 取 文件 ,对 数据 类 型 的 使 用 要 求 较 高 ,要 求 开发 者 在 存 取 过 程 中 对 
变量 的 存 取 顺序 有 非常 清醒 的 认识 ,任何 读 写 顺序 错误 和 类 型 错误 都 会 导致 严重 后 果 。 因 
此 ,这 种 读 取 技术 在 图 像 文档 、 声 音 文档 的 管理 领域 使 用 较 多 。 


11.2.3 文件 管理 


除了 对 文件 的 读 写 操作 外 , .NET 还 专门 提供 了 两 个 类 File 和 FileInfo, 对 文件 实施 整 


体 上 的 管理 。 
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Nt 


13 using System. IO: 

143-using System,Text:; 

15: 

l6g namespace FileGL 

17i| { 

18 澡 public partial class FileText : System. Web.UI.Page 

19: 

20im protected void Page_Load(object sender, Eventhrgs e) 

21: 

22! 

23iF } 

24! 

25 提 protected void btnSave_Click (object sender，Eventhrgs e) 

26 { 

27 String dfn = txtDfn. Text.Trim(); // 获 取 目 标 文件 名 

28 String tdata = txtData. Text. Trin(); 

29 String path = Server. MapPath(""); // 获 取 应 用 程序 的 绝对 路 径 
30 dfn = Path. Combine (path, dfm) ; /7 拼合 目标 文件 名 与 路 径 
31 try 

32 { 

33: TextWriter tw = new StreamWriter (dfn, true); 

34 // 创 建 TextWriter 对 象 ,而 且 是 允许 添加 模式 
35 tw. Write (tdata) ; // 把 获得 的 字符 吊 写 入 tw 对 象 中 。 

36 tw. FlushO); 

3T tw.Close(); 

38 }catch(Exception eee) {} 

39| } 

40 

41 和 protected void btnCls_Click(object sender, Eventhrgs e) 

42 { 

43 txtData. Text = ""; 

44i } 

45 

46 和 protected void btnRead_Click (object sender, Eventhres e) 

4T 

48 String dfn = txtDfm Text, Trin() ; /7 获取 目标 文件 名 

49 String path = Server. MapPath(""); // 获 取 应 用 程序 的 绝对 路 径 
50 

51 dfn = Path.Combine (path，dfn); ” /拼合 目标 文件 名 与 路 径 
52 TextReader tr = new StreanReader (dfn); 

53 String tdata = tr.ReadToEnd() ; 

54 tr,Close(); 

55 txtData. Text = tdata; 

56 钻 } 

57i 

58i 上 -} 


图 11-12 “利用 TextWriter 类 保存 输入 信息 ”程序 的 C# 源 代码 


1. File 类 与 Filelnfo 类 

与 Directory 类 和 DirectoryInfo 类 相似 , File 类 是 静态 类 ,其 方法 的 调用 以 “File. 方法 
名 (参数 )” 方 式 直接 执行 。 而 FileInfo 类 是 对 象 型 的 类 ,其 操作 建立 在 FileInfo 对 象 的 基础 
上 ,必须 先 建立 FileInfo 对 象 , 然 后 以 “对 象 名 .方法 名 (参数 )” 的 方式 执行 命令 。 

1) File 类 的 常见 方法 

File 类 的 主要 方法 及 其 用 法 见 表 11-8。 


表 11-8 File 类 的 主要 方法 及 其 用 法 


方法 名 说 上 明 
Open( 文 件 标志 ) 打开 指定 的 文件 ,返回 FileStream 类 型 
Copy( 源 文件 ,目标 文件 ,可 否 覆 盖 ) 实施 文件 的 复制 
Move( 源 文件 ,目标 文件 ) 实施 文件 的 移动 
Delete( 文 件 标 志 删除 指定 文件 


Exists( 文 件 标志 ) 检查 文件 是 否 存在 
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续 表 
方 法 名 说 明 
Create( 文 件 标志 ) 以 FileStream 方式 创建 一 个 文件 
CreateText( 文 件 标志 ) 以 StreamWriter 方 式 创建 一 个 文本 文件 
OpenText( 文 件 标志 ) 以 StreamReader 方 式 打开 一 个 文本 文件 
OpenRead( 文 件 标志 ) 打开 指定 文件 ,并 允许 读 取 ,命令 返回 FileStream 型 量 
OpenWrite( 文 件 标志 ) 打开 指定 文件 ,并 允许 写 入 ,命令 返回 FileStream 型 量 
AppendText( 文 件 标志 ) 创建 一 个 可 以 追加 Text 数据 的 文件 ,命令 返回 StreamWriter 
型 量 
AppendAllText( 文 件 ,内 容 , 编 码 方式 ) ”将 指定 的 字符 串 追 加 到 “文件 ”中 
2) FileInfo 类 的 常见 方法 
FileInfo 类 的 主要 方法 及 其 用 法 见 表 11-9。 
表 11-9 FileInfo 类 的 主要 方法 及 其 用 法 
方 法 名 说 ”有明 
CopyTo( 目 标 文件 标志 ,是 否 可 覆盖 ) 把 当前 文件 复制 到 指定 文件 标志 
MoveTo( 目 标 文件 标志 ) 把 当前 文件 移动 到 指定 文件 标志 
Delete() 删除 当前 文件 
OpenRead() 创建 只 读 型 FileStream 
OpenWrite() 创建 只 写 型 FileStream 
AppendText() 创建 一 个 可 以 追加 Text 数据 的 文件 ,命令 返回 StreamWriter 
型 量 
CreateText() 以 StreamWriter 方式 创建 一 个 文本 文件 
OpenText() 以 StreamReader 方式 打开 一 个 文本 文件 


2. 文件 管理 的 简要 示例 
1) 删除 指定 文件 的 示例 
先 判断 path 指示 的 文件 是 否 存在 ,如 果 存 在 就 删除 它 。 如 下 : 


if(File. Exists(path)) File. Delete(path); 
或 者 
if(File. Exists(path)){FileInfo ff = new FileInfo(path); ff.Delete();} 


2) 复制 指定 文件 的 示例 

先 判断 当前 文件 夹 中 是 否 存 在 文件 mmm. txt, 如 果 存 在 ,就 将 其 复制 到 当前 文件 夹 的 
下 级 文件 夹 paper 中 。 

方法 1: 

String path = Server. MapPath(""); 

String fnl = Path. Combine( path, @"mmm. txt" ); 


String fn2 = Path. Combine( path, @"paper\mmm. txt"); 
if(File. Exists(fn1)) File. Copy(fnl, fn2, false); 
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方法 2: 


String path = Server. MapPath(""); 
String fnl = Path. Combine(path, @"mmm. txt"); 
String fn2 = Path. Combine( path, @"paper\mmm. txt") ; 
if(File. Exists(fn1)) { 
FileInfo finfo = new FileInfo(fn1); 
finfo. CopyTo(fn2, false); } 


(11.3 ”把 文 件 上 传 到 服务 器 的 文件 夹 内 


A 


11.3.1 ASP. NET 实现 文件 上 传 的 关键 技术 


FileUpLoad 是 ASP.NET 为 客户 上 传 文件 而 专门 制作 的 一 个 控件 ,这 个 控件 集 屏幕 显 
示 和 文件 操作 于 一 体 , 具 有 非常 强大 的 功能 。 

1. 文件 上 传 控件 FileUpLoad 界面 

FileUpLoad 控件 位 于 【工具 箱 ] 的 [标准 ] 栏 目下 ,可 像 其 他 控件 一 样 被 直接 拖 动 到 Web 
窗 体 中 。 被 添加 到 窗 体 中 的 FileUp 控件 显示 为 如 图 11-13 所 示 的 形式 。 

图 11-13 中 左 侧 的 文本 框 是 一 个 只 读 的 文本 框 ,用 


于 显示 用 户 准备 上 传 的 文件 的 信息 。 .| 
用 户 可 单 击 右 侧 的 [浏览 ] 按 钮 ,系统 将 启动 一 个 [ 打 


图 11-13 “文件 上 传 ?程序 的 
开 文件 ] 对 话 框 ,此 时 就 能 直接 选择 文件 了 。 被 选中 者 的 入 各 半 


信息 显示 在 【浏览 3 按钮 前 面 的 文本 框 中 。 

2. 文件 上 传 控件 的 关键 属性 与 方法 

FileUpLoad 有 一 个 关键 属性 PostedFile, 其 子 属性 反映 了 被 上 传 文件 的 关键 信息 。 其 
关键 的 子 属性 及 方法 如 表 11-10 所 示 。 


表 11-10 FileUpLoad 属性 PostedFile 的 主要 子 属性 、 方 法 及 其 用 法 


子 属性 名 /方法 名 用 途 
FileName 被 上 传 文件 的 文件 名 
ContentLength 被 上 传 文件 的 大 小 
ContentType 被 上 传 文件 的 MIME 类 型 
SaveAs( 新 的 文件 标志 ) 方 法 以 新 文件 标志 在 服务 器 上 保存 文件 ,要 求 使 用 完整 的 文件 标志 


3. 文件 上 传 的 基本 流程 

如 需要 实现 文件 上 传 ,必须 在 窗 体 中 放置 一 个 FileUpLoad 控件 和 一 个 Button 控件 ; 
用 户 利用 FileUpLoad 控件 选择 要 上 传 的 文件 ; 当 单 击 Button 按钮 时 ,由 Button 按钮 的 
Click 事件 触发 文件 上 传 处 理 过 程 如 下 。 

首先 ,获取 用 户 上 传 文件 的 文件 名 。 

其 次 ,获取 存放 上 传 文件 的 文件 夹 的 完整 路 径 信息 。 

再 次 ,把 文件 夹 的 完整 路 径 与 上 传 文件 名 合并 ,形成 新 的 ,完整 的 文件 标志 。 
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最 后 ,调用 上 传 控件 的 PostedFile. SaveAs( 完 整 文件 标志 ) 方 法 在 服务 器 上 保存 文件 ， 


完成 上 传 过 程 。 


事实 上 ,在 实际 应 用 中 ,通常 还 需要 考虑 上 传 文件 的 重 名 问题 文件 信息 的 保存 问题 。 


在 下 面 的 案例 中 将 会 具体 讨论 相关 的 解决 方法 。 


11.3.2 ASP.NET 实施 文件 上 传 示例 


1. 文件 上 传 的 基本 应 用 示例 
1) 案例 要 求 


设计 如 图 11-14 所 示 的 程序 ,要 求 能 够 允许 用 户 从 客户 机 中 选择 文件 ,然后 上 传 到 本 应 
用 程序 下 的 UpLoads 文件 夹 中 。 如 果 应 用 系统 的 根 文件 夹 中 没有 Uploads 文件 夹 , 则 自动 


建立 一 


襄 必 天 ” 乱 天 ER 


请 选择 文件 并 上 传 ， 


11-14 “利用 FileUpLoad 实施 文件 上 传 ”程序 的 运行 效果 图 


2) 设计 方法 


新 建 窗 体 FileUp. aspx, 在 其 中 加 入 一 个 FileUpLoad 控件 和 一 个 Button, 适 当 排 列 其 
位 置 ,并 添加 必要 的 文字 说 明 , 如 图 11-14 所 示 。 设 置 按钮 控件 的 名 字 为 btnUp、Text 属性 
为 * 上 传 文件 ”, 然 后 在 代码 隐藏 页 中 编辑 ,为 btnUp 按钮 编写 代码 。 


相应 的 程序 代码 如 图 11-15 所 示 。 


15 日 nanmespace FileGL 
{ 


17im public partial class FileUp : System.Web.UI.Page 

18 { 

19i9 protected void Page_Load(object sender, EventArgs e) 

20 { 

21 

22 } 

23 

24 晶 protected void btnUp_Click (object sender，EventArgs e) 

25 

26 String path = Server. MapPath(@"\") ; We ee 

27 path = path + @"\uploads"; /查找 Uploads 子 文件 来 

28 if (IDirectory. Eists (path)) _// 如 果子 文 件 夹 不 存在 ， 则 创建 
29 e Cr 

30 String fn = FileUploadl. PostedFile. FileNane; 人 过 向 二 全 康 御 的 广 件 名 
31 String newfn = Path.Combine (path，fn); ”// 形 成 新 的 文件 

323 FileUpload!. PostedFile. SaveAhs (nevfn) ; // 折 上 代 妇 件 保存 到 eb 服务 吕 
33 if (File.Exists(newfn)) 

34 Response. Write("《Script>alert ("文件 上 传 成 功 ! ') ;</ Script>") ; 


图 11-15 “利用 FileUpLoad 实施 文件 上 传 ”程序 的 C# 源 代码 


注意 ; 因为 使 用 了 Path 类 ,本 程序 需要 引入 System. IO 命名 空 


间 。 本 程序 在 Windows 7 


下 调试 通过 。 如 果 系统 是 Windows XP, 一 般 用 “String fn 二 FileUpload1. FileName; ”来 获 


取 上 传 文件 的 文件 名 。 
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2. 文件 上 传 的 高 级 应 用 示例 

已 知 在 数据 库 XSGL 中 已 经 存在 数据 表 “ 文 件 表 ”, 专 门 用 于 存储 用 户 上 传 的 文件 的 信 
息 。 其 结构 为 : ID( 自 动 增 量 的 标志 字段 ,主键 ) ,文件 名 称 、 文 件 主题 上传 日 期 上 传人 。 

1) 案例 要 求 

设计 如 图 11-16 所 示 的 程序 ,使 用 户 能 够 把 选中 的 文件 上 传 到 Web 应 用 程序 所 在 的 
Uploads 文件 夹 ,并且 把 上 传 的 文件 名 信息 保存 在 数据 库 XSGL 的 数据 表 “ 文 件 表 ” 中 ,而 且 
在 窗 体 底部 GridView 中 显示 出 已 经 上 传 文件 的 信息 。 要 求 : 如 果 出 现 文件 重 名 现象 ,请 重 
新 为 上 传 的 文件 命名 ; 如 果 Uploads 文件 夹 不 存在 , 则 帮助 用 户 创建 一 个 。 


.a Ed 区 ~ 园 -* 己 蜗 * 


文件 上 传 示意 图 


ID | 文件 名 | 文件 主题 上 传 日 期 
2 lookprg 2011/2/12 00000 
1 mobanpsd 2011/2/12 00000 


图 11-16 “文件 上 传 "高 级 程序 的 运行 效果 图 


2) 设计 思路 

根据 图 11-16 要 求 ,在 窗 体 中 放置 必要 的 控件 。 因 为 要 把 上 传 文件 的 文件 名 、 上 传 日 期 
和 上 传人 信息 保存 到 数据 库 中 ,而 且 需 要 用 GridView 显示 文件 表 的 内 容 ,因此 可 以 借用 
LINQ 技术 实现 数据 库 的 查询 与 更 新 功能 。 

上 传 的 文件 名 可 以 取 自 上 传 控件 的 PostedFile 属性 的 FileName 子 属 性 ,上 传 日 期 可 以 
取 系 统 的 当前 时 间 (DateTime. Now) ,而 上 传人 信息 可 以 从 登录 界面 的 用 户 名 中 获取 。 因 
本 例 是 一 个 孤立 的 窗 体 ,故而 不 保存 "上 传人 ”的 信息 。 

本 案例 的 难点 在 于 对 文件 名 的 处 理 。 本 例 的 基本 思路 是 首先 检查 文件 名 是 否 超 长。 由 
于 开发 者 希望 文件 名 (不 超过 14 个 字符 (不 含 路 径 和 扩展 名 ) ,因此 ,如 果 文 件 名 超 长 就 对 文 
件 名 部 分 进行 截取 。 其 次 是 检查 在 服务 器 上 是 否 已 经 存在 同名 文件 ,如 果 存 在 同名 文件 , 则 
为 此 文件 添加 自然 序号 。 最 后 把 文件 用 通过 检测 的 新 文件 名 存储 到 服务 器 的 规定 位 置 内 。 

3) 设计 过 程 

(1) 新 建 窗 体 FileUpDifficult ,添加 必要 的 文字 说 明 信 息 。 然 后 ,在 窗 体 上 放置 文件 上 
传 控 件 FileUpLoad .按钮 Button 和 一 个 GridView ,分 别 命名 为 FileUpLoadl .btnUp 和 
gvWjb, 并 正确 设置 按钮 Button 的 Text 属性 为 “文件 上 传 ”。 

(2) 利用 GridView 的 智能 菜单 为 GridView 选择 一 种 较 好 的 格式 。 

(3) 新 增 LINQ to SQL 类 ,命名 为 Mydb, 然 后 从 【服务 器 资源 管理 器 面板 中 把 数据 连 
接 XSGL 中 的 数据 表 “ 文 件 表 ” 加 到 Mydb 的 数据 表 类 图 中 。 在 执行 此 操作 前 一 定 要 保证 
“文件 表 ” 已 经 设置 ID 为 主键 。 

(4) 为 按钮 btnUp 的 Click 事件 编写 代码 ,能 够 成 功 运行 的 代码 如 图 11-17 所 示 。 

4) 补充 说 明 

(1) 本 案例 需要 引用 命名 空间 System. IO。 
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[using Systei | 

15 namespace FileGL 

ii public partial class FileUpDifficult : System. Web. UI.Page 

: protected void Page Load(object sender, Eventires e) 
if (lIsPostBack) showDatal): 


} 

void showDatal) { 下 雪 把 所 区 村 雪 由 内 宫 
NydbDataContext db = new NydbDataContext() 
Var res = from r in db, 文 件 表 orderby r， 文件 名 select r 
gvFile.DataSource = res; 
gvFile. DataBind(); 


} 
protected void btnlp_Click (object sender, Eventhrgs e) 
' 


String path = Server. MapPath(@"\") ; // 获 取 应 用 系统 的 根 文件 夹 

path = path + @"\Uploads" ; /1 查找 p10ads 子 文件 夹 

if (IDirectory.Exists(path)) V/ 如 果子 文件 来 不 存在 ， 则 创建 
Directory.CreateDirectory (path) ; 

String fn = FileUploadl.PostedFile.FileName: // 获 取 上 传 文 件 的 文件 名 


/1 分 析 文件 名 结构 ， 形 成 新 的 文件 名 
String fnl = Path.GetFileNameWithoutExtension (fn) ; 
String fn2 = Path. GetExtension(fn) ; 
int i = 0, m = fnl.Length; 
(nn 》14)  “”// 如 果 文件 名 长 度 超过 14， 则 截 掉 后 面 的 部 分 


fnl = fnl, Substring (0，14); /;/ 截 取 文 件 名 的 前 14 个 字符 
fn = fnl + fn2; 
m= 14; 

} 

String newfn = Path.Combine (path, fn):; 


while (File.Exists (nevfm)) 
// 如 果 同 名 文件 已 经 在 服务 器 上 存在 
fnl = fnl.Substring (0, rm)+i.ToString().Trim(); 
fn = fnl + fn2; ”// 文 件 名 添加 序号 后 ;重新 形成 文件 名 
newfn = Path. Combine (path, fn); 


es 
/加 时 同名 文件 在 服务 器 上 不 存在 且 不 超 长 ， 则 保留 此 文件 名 


FileUploadl.PostedFile. Savehs (newfm) ; // 把 上 传 文件 保存 到 Web 服 务 器 
NydbDataContext db = new NydbDataContext () ; 


文件 表 wjb=new 文件 夫 () ; /1 利用 LINAQ 技 术 把 文件 信息 保存 起 来 
wjb, 文件 名 =fn; 

wjb. 上传 日 期 =DateTime. Today: 

邮 , 文 件 表 . InsertOnSubnit (wjb) ; /执行 插入 操作 

db, SubmitChanges () ; // 把 更 新 尽 启 到 后 台数 据 库 


showvDataf) ; 
证 (File,Exists (newfn)) 
Response. Write("<Script>alert(' 文 件 上 传 成 功 ! ') ;AScript>") ; 


图 11-17 “文件 上 传 "高 级 程序 的 C# 源 代码 


(2) 为 了 能 够 方便 地 显示 出 文件 表 中 的 信息 ,本 例 专门 编写 了 一 个 函数 showData, 用 
于 把 文件 表 中 的 内 容 显 示 在 GridView 中 ,本 函数 可 随时 调用 。 

(3) 如 果 把 此 窗 体 放 在 一 个 信息 系统 中 ,那么 可 以 利用 Session 变量 (自主 开发 登录 模 
块 ) 或 者 User. Identity. Name( 使 用 内 置 的 成 员 资格 管理 体系 开发 登录 模块 ) 为 文件 表 的 
“操作 人 ”字段 自动 赋值 ,从 而 自动 记录 操作 者 ,以 便 发 现 非法 文件 时 能 够 及 时 追查 责任 人 。 
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(4) 程序 第 35 行 中 的 语句 “String fn = FileUploadl. PostedFile. FileName; ”在 
Windows XP 中 简写 为 “String fn 二 FileUpload]1. FileName;”。 

3. 为 上 传 的 文件 提供 下 载 的 链接 

对 于 上 例 提供 的 文件 上 传 并 把 该 文件 的 信息 存储 到 数据 表 中 的 案例 ,还 可 以 利用 
GridView 技术 中 的 HyperLink 列 提供 文件 下 载 的 功能 。 其 具体 方法 为 : 在 Web 窗 体 中 添 
加 GridView 控件 ,利用 智能 菜单 中 的 【自动 套用 格式 】 适 当 设 置 GridView 控件 的 外 观 。 然 
后 利用 智能 菜单 [编辑 列 ] 打 开 列 【字段 ] 对 话 框 ,为 GridView 添加 HyperLinkText 列 ,设置 
该 列 的 HeaderText、DataNavigateUrlFields 和 DataNavigateUrlFormatString 属性 的 值 ,如 
图 11-18 所 示 。 


可 用 字段 (A): 
日 boundfield 
同 CheckBoxField 
A Hypertinkfield 
国 ImageField 
A Buttonfield 
CommandField 
| “Templatefield 


bs 


闭合 动 生成 字段 (G) 


图 11-18 文件 列表 [字段] 功能 的 操作 界面 


由 于 在 数据 表 的 [文件 名 了 字段 中 仅 包含 文件 名 的 信息 ,没有 包括 文件 存放 路 径 的 信息 ， 
为 此 需要 在 DataNavigateUrlFormatString 属性 中 通过 设 定格 式 “uploads/{0)” 来 设置 下 载 
文件 的 路 径 , 然 后 由 系统 自动 用 “文件 名 称 ” 中 的 信息 取代 格式 中 的 参数 “(0)”, 形 成 含有 路 
径 的 文件 标志 。 这 是 解决 欲 显示 数据 与 字段 内 容 有 差异 的 一 种 有 效 方式 。 

另外 ,由 于 存储 在 文件 表 的 “文件 名 ”字段 中 的 字符 串 末 尾 可 能 存在 空格 ,进而 导致 无 法 
正确 地 产生 连接 字符 串 。 为 此 ,可 通过 改进 LINQ 的 查询 语句 来 修正 这 一 问题 。 修 正 
图 11-7 中 的 第 25 行 ,使 之 成 为 如 图 11-19 所 示 格 式 , 就 能 有 效 地 解决 “文件 名 ”字段 中 信息 
末尾 的 空格 问题 ,而 且 把 查询 结果 的 列 名 修改 成 了 “文件 名 称 ”。 


亚 Var res = fron x in dp. 文 伴 委 orderby r. 文 伴 名 
26 select new{ 


27| 文件 名 称 =r. 文 件 名 .Trin0)， 
28 r. 文 件 主题 ， 

29 r. 上 传 日 期 

30 1 


11-19 利用 LINQ 技术 获取 文件 名 称 等 信息 的 查询 表达 式 
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11.3.3 针对 Windows 禁止 上 传 大 文件 的 解决 方案 


在 Web 应 用 系统 的 开发 中 ,常常 面临 这 样 一 种 篮 偿 的 情况 ,运行 中 的 Blog 系统 或 者 网 
上 销售 系统 仅 允许 用 户 上 传 200KB 以 下 的 小 文件 ,或 者 仅 允许 用 户 上 传 不 超过 4MB 的 文 
件 。 这 种 情形 是 由 Windows 操作 系统 或 ASP.NET 对 上 传 文件 的 默认 约束 引起 的 ,其 目的 
是 避免 用 户 上 传 过 大 的 文件 ,影响 服务 器 的 并 发 能 力 。 

如 果 服 务 器 具有 和 较 强 的 信息 处 理 能 力 ,而 且 确实 需要 上 传 较 大 的 文件 ,那么 可 以 通过 以 
下 方法 放宽 这 种 约束 。 

1. 放宽 Windows Server 2003 对 上 传 文件 长 度 的 限制 

Windows Server 2003 的 默认 设置 限定 了 上 传 文件 的 最 大 值 ,规定 上 传 文件 不 能 超过 
200KB, 如 果 文 件 的 容量 超过 这 个 限度 ,系统 将 拒绝 上 传 并 报错 。 

解决 办 法 是 修改 其 默认 设置 ,改变 Windows Server 2003 对 上 传 文件 大 小 的 限制 。 具 
体 步骤 如 下 。 

(1) 在 Windows Server 2003 服务 器 上 利用 [控制 面板 】->【 管 理工 具 ] 找 到 [服务] 项 , 启 
动 * 服 务 管理 器 ”, 然 后 停止 IIS Admin service 服务 。 

(2) 从 文件 夹 Windows\system32\inesrv\ 下 找到 配置 文件 metabase. xml, 编 辑 其 中 的 
ASPMaxRequestEntityAllowed 项 ,将 默认 的 204 800 改 为 需要 的 值 ( 如 20 480 000), 增 大 
Windows Server 2003 允许 上 传 文件 的 限制 值 。 

(3) 重新 启动 IIS Admin service 服务 。 

2. 放宽 ASP.NET 禁止 上 传 超过 4MB 文件 的 限制 

为 了 保证 服务 器 的 并 发 处 理 能 力 ,防止 某 个 用 户 的 上 传 文件 流 长 时 间 占 用 服务 器 资源 ， 
ASP.NET 默认 配置 为 , 上 传 文件 的 上 限 为 4MB, 拒 绝 上 传 超过 4MB 的 文件 。 然 而 ,如 果 
系统 确实 需要 允许 用 户 上 传 大 型 文件 , 则 可 以 通过 修改 Web. config 文件 放宽 这 一 限制 。 具 
体 方 法 是 : 在 Web. config 的 过 System. Web 之 节 中 加 入 语句 “< HttpRuntime 
maxRequestLength=" 新 容量 " / 盖 ”, 用 以 设 定 允 许 上 传 的 文件 的 最 大 容量 。 

由 于 该 语句 以 KB 为 单位 ,所 以 语句 “二 HttpRuntime maxRequestLength 王 "10240" /二 ” 
代表 允许 上 传 的 最 大 文件 为 10MB。 

注意 ; 并 不 是 允许 上 传 的 文件 越 大 越 好 。 由 于 单个 用 户 上 传 大 文件 时 ,可 能 会 导致 该 
文件 长 时 间 占 用 服务 器 的 网 络 端口 ,影响 其 他 用 户 对 系统 的 访问 。 所 以 ,在 具体 的 Web 应 
用 系统 中 ,应 该 根据 实际 需要 ,为 上 传 文件 限定 尽 可 能 小 的 数值 。 


人 .4 把 文件 上 传 到 服务 器 的 数据 库 内 


让 用 户 把 文件 上 传 到 服务 器 的 指定 文件 夹 中 ,能 够 有 效 地 解决 用 户 向 服务 器 上 传 文件 
的 需求 。 但 这 一 方法 也 有 其 缺陷 : 首先 , 当 多 用 户 向 服务 器 上 传 文件 时 ,难免 出 现 文件 重 名 
文件 ,为 解决 文件 重 名 而 采取 的 措施 可 能 会 引发 用 户 的 反感 ; 其 次 , 当 一 个 文件 夹 中 文件 
的 数量 过 多 时 ,可 能 会 引起 服务 器 响应 时 间 过 长 的 问题 。 测 试 发 现 ,如 果 在 一 个 文件 夹 中 直 
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接 存 放 了 1000 个 以 上 的 直属 文件 ,服务 器 对 此 文件 夹 的 检索 效率 就 很 低 ,其 性 能 很 不 理想 。 
而 且 , 随 着 文件 的 增加 ,其 性 能 下 降 的 速度 非常 快 。 为 此 人 们 提出 了 一 种 把 文件 存储 到 数据 
库 中 的 策略 。 

把 文件 上 传 到 服务 器 上 的 数据 库 中 ,使 文件 作为 数据 库 中 的 一 条 记录 存储 起 来 ,这 一 策 
略 能 够 有 效 地 解决 不 同 用 户 文件 重 名 的 问题 ,也 可 以 解决 数据 高 速 检索 的 问题 ,是 一 种 有 效 
的 处 理 策略 。 但 对 过 于 庞大 文件 ,其 处 理 仍 不 够 理想 ,存在 着 一 些 局 限 性 。 因 此 ,大 多 数 的 
Web 应 用 系统 并 不 推荐 把 庞大 的 文件 存放 到 数据 库 中 。 


11.4.1 把 文件 上 传 到 服务 器 数据 库 内 的 基本 方法 


1. 把 文件 上 传 到 服务 器 的 数据 库 内 的 基本 思路 

首先 ,要 为 文件 内 容 的 存储 在 数据 库 中 设计 专门 的 字段 。 由 于 在 计算 机 系统 中 存在 着 
各 种 类 型 的 文件 ,要 把 文件 存储 到 数据 库 中 ,需要 为 存储 文件 内 容 而 专门 设置 一 个 字段 。 
SQL Server 2000 及 以 前 的 版 本 使 用 Image 类 型 存储 文件 内 容 ,而 SQL Server 2005 及 以 后 
的 版 本 采用 varBinary(MAX) 类 型 存储 文件 内 容 , 这 种 字段 结构 最 大 支持 2GB 大 小 的 文 
档 , 而 且 支 持 使 用 LINQ 技术 直接 处 理 。 

其 次 ,利用 FileUpLoad 上 传 控件 把 文件 上 传 到 服务 器 上 ,然后 利用 PostedFile 的 
FileName、FileType 和 FileLength 获取 文件 的 名 称 、 类 型 和 长 度 ,通过 流 (Stream) 对 象 从 
PostedFile 中 获取 字 节 型 数组 的 文件 内 容 。 

最 后 ,利用 LINQ 技术 把 文件 名 称 长度. 上 传 日 期 .类 型 等 信息 上 传 到 数据 库 的 对 应 字 
段 中 。 

2. 把 文件 上 传 到 数据 库 内 的 关键 技术 

把 文件 上 传 到 数据 库 内 的 关键 技术 主要 包括 : 

。 数据 表 及 varBinary(MAX) 类 型 。 

。 FileUpLoad 控件 及 其 应 用 技术 。 

。 Stream 对 象 及 其 应 用 技术 。 

。 LINQ 的 数据 插入 技术 。 


11.4.2 把 文件 上 传 到 服务 器 的 数据 库 内 的 示例 


1. 案例 要 求 

用 户 能 够 通过 本 地 客户 机 的 浏览 器 选择 文件 ,并 把 文件 上 传 到 服务 器 上 的 数据 库 内 ,并 
以 列表 方式 显示 出 数据 库 内 存储 的 文件 目录 ,如 图 11-20 所 示 。 

2. 准备 工作 

首先 ,利用 [服务 器 资源 管理 器 ] 面 板 在 【数据 连接 ] 中 找到 XSGL 连接 ,为 此 连接 添加 
一 个 数据 表 “ 文 件 内 容 表 ”。 文 件 内 容 表 的 结构 为 文件 名 、 文 件 类 型 、 上 传 时 间 ,文件 内 容 、 上 
传人 、 文 件 长 度 字段 。 其 中 “文件 内 容 " 字 段 为 varBinary (MAX) 类 型 ,上 传 类 型 为 nChar 
型 .宽度 28, 上 传 时 间 为 DateTime 型 。 另 外 添加 字段 ID, 设置 为 INT 型 ,为 标识 种 子 , 自 增 
量 是 1, 以 ID 作为 此 表 的 主键 。 

其 次 ,为 当前 项 目 添加 *LINQ to SQL” 类 MydbDataContext, 把 “文件 内 容 表 ”添加 到 
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MydbDataContext 的 数据 表 类 视图 中 ,使 之 处 于 可 使 用 LINQ 技术 实施 操作 的 状态 。 

3. 设计 运行 界面 

1) 添加 控件 

在 项 目 中 新 增 窗 体 FileContent, 然后 按照 图 11-20 所 示 的 格式 添加 3 个 控件 : 
FileUpLoad 控件 、Button 控件 和 GridView 控件 ,并 依次 修改 3 个 控件 的 ID 为 MyFile、 
btnUp 和 gvFile。 


GO pupy//localhosts9182/FleConte |B||X | 月 Be P *| 
庄 届 着 天 5 和食 "- 目 " 呈 生 -DD- 229” IRO- ” 
CR | - 
ID 文件 名 “文件 类 型 上 传 时 间 上 传人 文件 长 度 显示 文件 内 容 另存 文件 删除 
25 zzzhaml 。 texthtml |2011/2/14 3828 ”| 选择 25 保存 。 删除 
26 ma43 bt textiplan 2011/2/14 690 选择 26 保存 删除 5 
28 |bg jpg image/pipeg 2011/2/14 1905 选择 28 保存 删除 | 
29 bk03jpg image/pipeg 2011/2/14 18798 。 | 选择 29 保存 删除 | 
30 |tongzhi 09 gf image/gf ‘2011/2/14 1517 选择 30 保存 删除 


虽 


11-20 “把 文件 上 传 到 服务 器 上 数据 库 内 ”程序 的 运行 效果 图 


2) 对 控件 进行 必要 的 配置 

首先 ,利用 GridView 控件 的 智能 菜单 为 GridView 套用 格式 ,使 之 比较 美观 。 

其 次 , 对 GridView【 编 辑 列 】 取消 其 "自动 生成 字段 ”为 GridView 设置 5 个 
BoundField 列 ,并 分 别 设置 其 DataField 属性 为 “ID、 文 件 名 ,文件 类 型 上传 时 间 、 上 传人 、 
文件 长 度 ”。 然 后 为 GridView 添加 “删除 ” 列 , 以 便利 用 GridView 实现 文档 管理 。 

最 后 ,利用 [属性 面板 ,设置 GridView 中 的 AutoPaging 属性 为 true, PageSize 属性 为 
5。 然 后 切换 到 [属性 面板 的 [方法 选项 卡 下 ,双击 “PageIndexChanging” 项 ,自动 为 此 事件 
在 cs 文档 中 创建 方法 框架 ,再 双击 “RowDeleting” 项 ,自动 为 删除 事件 在 cs 文档 中 创建 空 
的 方法 。 以 便 以 后 为 换 页 功能 和 删除 功能 编写 相应 的 代码 。 

4. 编写 C 间 程序 代码 

切换 到 FileContent. aspx. cs 编辑 状态 ,为 FileContent. aspx 编写 代码 ,最 终结 果 如 
图 11-21 所 示 。 

注意 : 由 于 本 例 中 使 用 了 Stream 对 象 ,因此 需要 引用 System. IO 名 称 空间 。 


11.4.3 从 数据 库 内 获取 文件 内 容 


1. 从 数据 库 内 获取 文件 的 基本 思路 

对 于 存放 在 数据 库 内 的 文件 ,可 以 显示 在 用 户 的 浏览 器 中 。 或 者 根据 用 户 的 要 求 , 把 用 
户 指定 的 记录 转换 为 文件 ,并 存放 到 指定 的 位 置 , 供 用 户 下 载 。 

1) 形成 文件 并 存放 到 指定 位 置 

首先 ,直接 借用 LINQ 的 查询 技术 ,从 数据 库 中 读 取 文件 内 容 和 文件 名 称 ,获取 二 进 制 
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> 
(Binary) 类 型 的 文件 内 容 ; 其 次 ,把 文件 内 容 书写 到 指定 的 * 文 件 流 "对 象 中 ,形成 文件 ; 最 
后 ,为 此 文件 建立 可 以 下 载 的 超 链接 。 
2) 把 文件 内 容 显示 在 浏览 器 中 
首先 ,直接 借用 LINQ 的 查询 技术 ,从 数据 库 中 读 取 文 件 内 容 和 文件 类 型 ,获取 二 进 


制 (Binary) 类 型 的 文件 内 容 ; 其 次 ,向 浏览 器 输出 文件 类 型 ; 最 后 , 才 向 浏览 器 输出 文件 
内 容 。 
1 了 [using System. Knl. Ling: 
13iLusing System. I0; 
14: 
15 浊 mnamespace File6L 
16| 1{ 
17 加 public partial class FileContent : System. Web.UI.Page 
18 { 
19: NydbDataContext db = nev lydbDataContext () ; 
20 
21 吕 人 showDatal) /1 利用 LINQ 技 术 显示 数据 库 中 文件 内 容 表 内 容 的 方法 
224 
239 var res = from r in db. 文 件 内 容 表 orderby r. 上 传 时 间 select r; 
24i gvFile.DataSource = res; // 设 置 bridYiew 的 数据 当 
25: gvFile, DataBind(); AZ/ 剧 新 GridView 
26 
27 如 ee void Page_Load(object sender, Eventhres e) 
28i 
29 证 (ITsPostBack) showData() ; // 初 次 使 用 此 网 页 ， 先 以 列表 方式 显示 文件 内 容 表 的 内 容 
30 上 
31 
32i protected void btnUp_Click(object sender, Eventhres e) 
33j { 
34; 
35: int flLen = JFile,PostedFile,ContentLength; ”// 获 取 文 件 的 大 小 值 
36 string fName = jlyFile,PostedFile,FileName; 。 // 获 取 文 件 的 名 称 
37 string fType = jfyFile.PostedFile.Content1ype; // 得 到 文件 类 型 
38 
39! Strean fs = llyFile. PostedFile. InputStrean; 。“// 获 取 用 户 提交 的 文件 的 流 对 象 
40j byte[] fData = new byte[fLen] ; V/ 按 照 文 件 大 小 创建 字 节 赦 组 
3 fs.Read(fData, 0, fLen); /{ 把 文件 内 容 读 入 fData 数 组 中 
42 
43 文件 内 容 表 wjb = nev 文件 内 容 表 () ; 7/ 利用 LINQ 创 建 "文件 内 容 表 对 象 ” 
dd wjb. 文 件 名 = fNane; // 此 处 的 5 个 语句 实现 数据 蜂 值 
45 wjb. 文 件 类 型 = fType; 
d6 wjb. 上 传 时 间 = DateTine. Today; 
4dT wjb. 文件 长 度 = fLen; 
d8 wjb. 文件 内 容 = fData; 
49 由 .文件 内 容 表 , InsertOnSubmit (wjb) ; // 把 新 增 内 容 添加 到 DataContext 对 象 中 
50 db. SubnitChanges () ; // 更 新 后 台数 据 库 
51 
52 showDatal) ; 
53 Response. Write("《Script>alert(" 文件 上 传 成 功 !") ;</Script》") ; 
54 站 } 
55 
56 和 和 Protected void gvFile_PageIndexChanging (object sender， GridViewPageEventhrgs e) 
5 // 本 方法 响应 换 页 功能 
8 gvFile. PageIndex = e.JewPageIndex: // 获 取 当 前 外 码 号 
59: showDatal() ; // 重 新 刷新 6ridView 
60j 
61 
62 和 protected void gvFile_Rovleleting (object sender, GridViewDeleteEventhrss e) 
63 
6d: String cid = gvFile.Rows[e.RowIndex].Cells[0]. Tsxt: // 获 取 即 将 被 喇 文件 的 世 
| int id = Convert. ToInt32(cid. Trin()). // 把 文件 ID 转化 为 整 型 时 
66 
6T var recs = from r in 则 .文件 内 容 表 where r.ID == id select r;// 查 找 指定 ID 的 文档 
db. 文 件 内 容 表 . DeleteAllOnSubnit (recs) ; AZ/ 在 DataContext 中 执行 删除 
db. SubnitChanges () ; // 更 新 后 台数 据 诗 
showData() ; 
} 
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2. 从 数据 库 内 读 取 文 件 的 关键 技术 

从 数据 库 中 读 取 文 件 内 容 组 成 文件 的 相关 技术 主要 包括 GridView 的 “选择 ” 列 技术 、 
LINQ 的 数据 查询 技术 、Binary 类 型 与 byte[ ] 类 型 的 转换 技术 、 流 (Stream) 与 文件 流 
(FileStream) 技 术 文件 流 操作 技术 、 超 链接 与 下 载 技 术 。 

从 数据 库 中 提取 文件 内 容 并 在 浏览 器 中 显示 的 相关 技术 主要 包括 GridView 的 “ 超 链 
接 ” 列 技术 、LINQ 的 数据 查询 技术 、Binary 类 型 与 byte[ ] 类 型 的 转换 技术 、 向 浏览 器 书写 完 
整 文档 的 技术 。 


11.4.4 从 数据 库 内 读 取 文 件 的 示例 


为 前 例 中 的 程序 增加 两 个 功能 : 其 一 是 把 选 定 文件 的 内 容 显示 在 浏览 器 中 ; 其 二 是 把 
选 定 文件 的 内 容 另存 为 其 他 文档 ,以 供 下 载 。 

1. 把 选 定 文件 另存 为 其 他 文档 

1) 对 GridView 添加 “选择 ” 列 

首先 ,对 GridView 添加 “选择 ” 列 ,修改 相关 属性 ,如 图 11-22 所 示 。 


3: CommandField 属性 
FD BoundField 加 外 上 
| 团 checkBoxield EdidmageU| EE 
国 HypertinkField et 
| 加 Imagefied FooterText 
| 司 butonfield er | 
| 由 加 commandFald Ce xe > | 
加 Templatefield Insermaged 
InsertText 攻 入 | 上司 
RD) NewimageUr| | 
选 定 的 字段 (9): NewText 新 奸 | 
SelecimageUr 加 
Der 自 
DD 上 ty bl Updatelmage 
回 上 传人 | UpdateTerd 更 新 
加 文 作 长 度 a | 区 日 和 
用 文人 内 容 CausesValidation 。 True 
|aEE3 到 InsertVisible Tme 国 
Lasma ee depen ] 
是 自动 生成 字句 (G) 按 此 宰 欠 多 为 TemplateField 
Ww 


图 11-22 为 把 数据 表 内 的 信息 另存 而 编辑 GridView 列 


其 次 ,利用 [属性 面板 的 [方法] 选项 卡 , 为 “SelectedIndexChanged” 事 件 在 cs 文档 中 添 
加 相应 的 方法 框架 。 

2) 针对 GridView 的 “选择 ? 列 编写 代码 

能 够 实现 功能 要 求 的 最 终 代 码 如 图 11-23 所 示 。 

2. 把 选 定 文件 的 内 容 显示 在 浏览 器 的 新 窗口 中 

本 例 通过 GridView 中 的 超 链接 选择 要 输出 的 文件 并 调用 负责 显示 的 程序 ,然后 由 新 
程序 FileContShow. aspx 负责 把 选 定 的 文档 显示 在 浏览 器 的 新 窗口 中 。 

1) 对 GridView 添加 “HyperLinkField” 列 

首先 ,对 GridView 添加 “HyperLinkField” 列 ,修改 相关 属性 如 图 11-24 所 示 。 
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研 protected void gvFile_SelectedIndexChanged(object sender，Evwentargs e) 

74 引 人 

5 int id = Convert. ToInt32(gvFile. SelectedYalue. ToString ()) : // 获 取 选 中 文档 的 id 

6 var recs = fron r in 由. 文件 内 容 表 where r. 了 D 一 id select r:// 执 行 LINQ 查 询 
Var rec = recs.First (); 
byte[] fData = rec. 文 件 内 容 . Tohrray() ; // 把 文件 内 容 字段 的 值 转化 为 byte[] 型 
String path=Server. MapPath(@"\")+@"\FileTenp"; 人 全 相 抽 这 本 全 
String fn = patht"\\” + rec. 文 件 名 .Trin0); /1 设置 新 文档 的 完整 文件 名 
if (IDirectory. Exists (path)) /7/ 如 果 新 的 存 铺 文 件 来 不 存在 
Directory. CreateDirectory (path) ; /1 则 新 建立 一 个 
if (File, Exists (fn)) File.Delete(fm) : MA hp pr Et 则 先是 除 
FileStrean fs = new FileStrean(fn,，Filellode.Create) ; // 以 指定 的 文件 信息 创建 新 文件 流 
fs,Write(fData，0，fData.Length) ; // 把 文件 内 容 写 到 文件 流 中 
fs.Close(): // 关 闭 诡 件 流 
VV/ 创 建 关 于 下 载 的 树 接 

5tring strb = "您 的 文件 已 经 被 另存 为 " + rec, 文 件 名 + "。 您 可 可 以 直接 【" 
strb = strb + "Ca href=FileTenp/" + rec. 文 件 各 .Trin() + "> 下载 件 ] 人 /a>" 
lblRes. Text=: 


11-23 为 把 数据 表 内 的 信息 另存 而 编写 的 C# 源 代码 


可 用 字段 (A)}: HyperinkField 属性 ): 
FD BoundField 国 网 已 | 
| 团 checkBoxField 日 a “| 
| 加 bperlinkfeld 
| 司 magefad | FileContShow.aspx?id = -| ) 
上 加 ButtonField 
i CommandField | 
[加 Templatefield 日 外观 
FooterText | 国 
添 ho(D) Heades 
HeaderText 显示 文件 内 容 
区 Text 
因 。 末 
四 InsertVisible True J 
NavigateUr| 
站 四 


ShowHeader Tme 


11-24 为 把 数据 表 内 的 文件 内 容 显示 出 来 而 添加 HyperLinkField 列 


其 次 ,对 HyperLinkField 属性 的 配置 进行 说 明 。 

在 图 11-24 右 侧 的 HyperLinkField 属性 中 ,对 HyperLinkField 进行 了 多 项 配置 。 第 
一 ,设置 DataNavigateUrlFields 的 值 为 id, 指 明了 超 链 接 信息 与 数据 源 中 的 id 列 密切 相关 。 
而 DataNavigateUrlFormatString 属性 就 以 前 面 的 id 作为 参数 {0} 的 值 ,说 明了 超 链 接 要 调 
用 的 动态 网 页 名 称 及 需要 传递 的 参数 值 。 本 例 明 确 指出 , 超 链 接 的 字符 串 序 列 为 
“FileContShow. aspx? id 王 ”, 其 参数 值 由 前 面 的 DataNavigateUrlFields 指定 的 字段 提供 。 
第 二 , 紧 跟 其 后 的 DataTextField 和 DataTextFormatString 属性 则 设置 了 在 GridView 每 行 
中 要 显示 的 信息 和 格式 。 第 三 ,底部 Target 属性 值 为 ”Blank”, 表 示 在 一 个 新 窗口 中 打开 
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超 链接 。 

2) 新 增 Web 窗 体 FileContShow. aspx 

为 响应 超 链接 列 ,在 项 目 中 新 增 Web 窗 体 FileContShow. aspx, 并 对 此 文件 的 代码 隐 
藏 页 FileContShow. aspx. cs 进行 开发 ,针对 Page_Load 事件 编写 代码 ,最 终结 果 如 
图 11-25 所 示 。 


18 protected void Page Load(object sender, Eventhrgs e) 

19: 

20 int id =Convert.ToInt32(Request.QueryString["id"]) ; // 获 取 URL 传 递 来 的 参数 值 

浊 if (id!=0) 

22 { 

23 NydbDataContext db = new JrdbDataContext () ; /1 启用 LINQ 功 能 

24 var recs=fron + in db, 文 件 内 容 表 where r,ID==id select r; // 执 行 LINQ 的 查询 

25 if (recs.Count () == 0) // 如 果 文件 不 存在 ， 则 退出 系统 
26 | 

27 Response. Write ("您 选 定 的 文件 不 存在 !"); 

28: return; 

29 } 

30 Var rec = recs.First(). /获取 查询 到 的 首 条 记录 

31 byte[] fCont = rec. 文 件 内 容 .ToArray(); /1 获取 文件 内 容 

32: 

33 Response. ClearCont ent () ; // 清 空当 前 页 面 的 Content 预 置信 息 
34 Response.ContentType = rec. 文 件 类 型 . Trin() ; 。 /按照 文件 类 型 设置 页 面 的 Contert 类 型 
35 Response. BinaryWrite (fCont); // 把 文件 内 容 输出 到 浏览 器 中 

36 Response. End() ; /结束 输出 过 程 四 


图 11-25 为 把 数据 表 内 的 文件 内 容 显示 出 来 而 设计 的 C# 源 代码 


候 考 是 


1. 如 何 获取 指定 驱动 器 的 空闲 空间 ? 

2. 如 何 获 取 某 个 文件 夹 中 的 全 体 文件 与 文件 夹 ? 

3. 如 何在 指定 的 文件 夹 中 创建 一 个 新 文件 夹 ” 如 何 判断 在 一 个 文件 夹 中 是 否 存 在 某 
个 文件 ? 

4. 怎样 才能 把 当前 窗 体 中 文本 区 域 中 的 信息 存储 到 服务 器 的 指定 文件 夹 中 ? 

5. 在 Web 窗 体 中 ,通常 使 用 什么 控件 实现 文件 上 传 ?在 文件 上 传 对 象 中 ,如 何 获 取 被 
上 传 文件 的 文件 名 文件 类 型 和 文件 长 度 等 关键 信息 ? 

6. 如果 想 把 上 传 的 文件 保存 到 服务 器 的 指定 文件 夹 中 ,应 该 使 用 文件 上 传 对 象 的 什么 
方法 ? 该 方法 的 参数 是 什么 ? 

7. 在 服务 器 上 保存 上 传 文件 的 过 程 中 ,是 否 可 以 改变 文件 名 称 ? 

8. 在 文件 上 传 过 程 中 ,如 何 突破 服务 器 对 上 传 文件 大 小 的 限制 ? 

9. 在 文件 上 传 并 希望 保存 到 服务 器 文件 夹 中 的 过 程 中 ,通过 什么 方法 可 以 限制 上 传 文 
件 的 类 型 ? 

10. ASP .NET 是 否 允许 用 户 把 文件 存储 到 服务 器 中 的 数据 库 内 ? 在 SQL Server 
2005 中 ,通常 使 用 什么 类 型 的 字段 保存 文件 内 容 ? SQL Server 2005 为 什么 不 采用 Image 
字段 保存 文件 内 容 ? 在 数据 库 中 保存 文件 时 ,除了 保存 文件 内 容 ,通常 还 要 保存 什么 信息 ? 

11. 对 于 保存 到 数据 库 内 的 文件 ,如 果 需 要 显示 在 窗 体 中 ,应 该 使 用 什么 命令 ?如 何 防 
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止 浏览 器 不 能 正确 地 解析 文件 类 型 ? 


12. 对 于 保存 到 数据 库 内 的 文件 ,如 果 需 要 转 存 到 服务 器 的 特定 文件 夹 中 ,应 该 借助 什 
么 类 型 的 对 象 ? 应 该 注意 什么 ? 


仁 机 实 训 是 


新 建 项 目 TEST11 ,在 此 项 目 中 实现 以 下 功能 。 

(1) 新 增 窗 体 FILEINFO ,利用 此 窗 体 可 以 显示 出 指定 文件 夹 的 结构 ,把 该 文件 夹 下 的 
所 有 子 文 件 夹 名 称 和 全 体 文件 的 名 称 显示 出 来 。 

(2) 新 建 窗 体 FILEDIR ,利用 此 窗 体 可 以 在 指定 的 文件 夹 中 创建 子 文件 夹 。 

(3) 新 建 窗 体 FILEUPDIR ,利用 此 窗 体 可 以 选 定 文件 ,并 把 文件 上 传 到 服务 器 上 的 指 
定 文件 夹 UPLOAD 中 ,同时 把 上 传 文件 的 文件 名 ,文件 类 型 和 上 传 日 期 保存 到 后 台数 据 库 
的 数据 表 中 。 要 求 : 在 上 传 过 程 中 进行 文件 名 称 审查 ,如 果 同 名 文件 在 服务 器 上 已 经 存在 ， 
则 必须 先 调整 为 其 他 合法 的 文件 名 称 , 然 后 才能 保存 。 

(4) 新 建 窗 体 FILEUPDB, 利 用 此 窗 体 选 定 文件 ,然后 把 文件 上 传 到 服务 器 内 的 数据 库 
中 。 要 求 在 保存 文件 内 容 的 同时 ,在 数据 库 中 保存 上 传 文件 的 文件 名 、 文 件 类 型 和 上 传 
日 期 。 

(5) 基于 题目 (4) 的 设计 ,补充 编写 程序 ,实现 在 浏览 器 中 显示 出 指定 文件 的 内 容 的 功 
能 ,或 者 能 够 把 指定 的 文件 从 数据 库 中 转 存 到 服务 器 内 的 特定 文件 夹 中 。 


Web 服 务 器 与 网 页 发 布 


学 习 要 点 
本 章 主要 学 习 与 ASP.NET 应 用 程序 发 布 密切 相关 的 技术 。 要 求 了 解 IIS 服务 器 的 安 
装 与 安全 性 配置 技术 、 后 台数 据 库 管理 系统 的 安装 与 配置 技术 、.NET Framework 运行 环 
境 的 配置 技术 、ASP.NET 应 用 程序 的 发 布 技术 。 本 章 重 点 关注 以 下 内 容 : 
。 IIS 服务 器 的 安装 与 配置 方法 。 
。 网 站 与 虚拟 目录 的 概念 ,网 站 与 虚拟 目录 的 创建 方法 .访问 权限 设置 .默认 文档 ， 
.NET Framework 的 版 本 检测 与 配置 技术 。 
。 SQL Server 2005 的 安装 方法 、 基 础 配置 ,Management Studio 的 用 途 与 简单 用 法 ， 
数据 库 的 创建 与 附加 技术 。 
。 把 ASP.NET 应 用 程序 发 布 到 Web 服务 器 上 的 方法 。 


(12.1 网 站 运行 环境 简介 


— 


12.1.1 ASP.NET 网 站 的 平台 基础 


1. ASP .NET 网 站 运行 的 必需 软件 

由 于 真正 地 为 业务 活动 提供 服务 的 Web 应 用 系统 要 应 对 众多 用 户 的 并 发 访问 ,因此 不 
论 是 操作 系统 ,还 是 数据 库 管理 系统 、Web 服务 器 ,都 要 使 用 服务 器 版 本 的 ,只 有 如 此 才能 
保证 系统 的 性 能 ,具有 较 强 的 并 发 能 力 。 目 前 ,对 基于 ASP.NET 技术 的 Web 应 用 系统 ,一 
般 推荐 使 用 Windows Server 2003/2005/2008 作为 服务 器 操作 系统 ,以 IIS 6. 0/7. 0 构建 
Web 服务 器 系统 ,并 配置 .NET Framework 3.5 框架 。 

由 于 绝 大 多 数 的 Web 应 用 系统 都 需要 后 台数 据 库 的 支撑 ,而 且 ASP.NET 系列 的 应 用 
系统 多 数 与 SQL Server 配合 良好 。 特 别 是 ASP.NET 3. 5 的 默认 后 台数 据 库 就 是 SQL 
Server 2005。 因 此 ,要 配置 ASP.NET 的 应 用 系统 ,通常 以 SQL Server 2005/2008 为 ASP 
.NET 应 用 系统 提供 数据 库 支 持 。 所 以 ,通常 需要 在 Windows 服务 器 中 安装 并 配置 服务 器 
版 的 SQL Server 2005 数据 库 管 理 系统 。 

2. 系统 软件 的 逻辑 关系 

表 12-1 描述 了 ASP.NET 应 用 系统 中 各 个 软件 之 间 的 逻辑 关系 ,在 管理 员 配 置 与 管理 
Web 应 用 系统 时 ,可 以 按照 从 低 向 高 的 层次 逐 层 安 装 系统 软件 。 
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表 12-1 ASP.NET 的 系统 软件 之 间 的 逻辑 关系 


高 应 用 系统 Web 应 用 系统 (如 网 上 销售 系统 、 图 书馆 信息 管理 系统 ASP.NET 版 ) 


服务 器 端 : 可 不 安装 开发 工具 

开发 端 : Visual Studio . Net 2005/2008 

Web 服务 器 JIS( 支 持 .NET Framework 3.5 版 ) 

服务 器 端 SQL Server 2005 企业 版 

开发 端 : SQL Server 2005 开发 版 

服务 器 端 ; Windows Server 2003/2008 

开发 端 : Windows XP Professional 或 Windows 7 
底 裸 机 


12.1.2 IIS 服务 器 及 特点 


IIS 服务 器 (Internet Information Services,IIS) 是 微软 公司 为 Windows 平台 开发 的 一 
个 Web 服务 器 系统 。 目 前 它 的 功能 主要 包括 创建 Web 服务 器 ,创建 FTP 服务 器 和 创建 
SMTP 虚拟 服务 器 。 也 就 是 说 ,一 个 具有 静态 外 部 IP 地 址 .已 经 连接 到 Internet 的 计算 机 ， 
在 安装 了 Windows Server 2003/XP 操作 系统 后 ,如 果 安 装 上 IIS, 此 计算 机 就 可 以 成 为 一 台 
Web 服务 器 ,能 够 为 普通 用 户 提供 Web 服务 和 FTP 服务 。 

1. lIS 服务 器 类 型 及 其 特点 

JIS 服务 器 能 够 与 Windows Server 系统 无 缝 结合 ,实现 优良 的 效果 。 当 前 ,基于 
Windows 服务 器 的 IIS 服务 器 主要 有 IIS 6.0 和 IIS 7. 0 两 个 版 本 。 其 中 IIS 6. 0 可 以 运行 
在 Windows XP 和 Windows Server 2003 操作 系统 上 ,而 IIS 7.0 则 主要 工作 于 Windows 7 
和 Windows Server 2008 操作 系统 之 上 。 

Windows 2000 的 服务 器 版 ,专业 版 、Windows XP 的 Professional 版 和 Windows 
Server 2003 都 能 够 安装 IIS 并 提供 相关 服务 。 但 是 ,在 Windows 2000 专业 版 和 Windows 
XP 上 安装 IIS 后 构成 的 Web 服务 器 , 仅 能 支持 10 个 并 发 用 户 访问 。 因 此 ,这 种 IIS 通常 用 
于 实验 室 研 究 和 个 人 用 户 进行 程序 调试 。 而 Windows 2000/2003 服务 器 版 能 够 提供 更 安 
全 和 性 能 更 强 的 服务 、 允 许 更 多 的 用 户 访问 服务 器 ,是 IIS 式 的 Web 服务 器 的 专业 应 用 。 
与 IIS 6.0 版 本 相似 ,基于 Windows 7 的 JIS 7.0 是 面向 应 用 系统 开发 ,测试 目的 的 , 仅 允许 
少量 的 并 发 用 户 测试 使 用 。 而 基于 Windows Server 2008 的 JIS 7. 0 才 可 真正 地 提供 企业 
级 服务 ,为 大 量 的 并 发 访问 提供 支持 。 

IIS 是 Windows Server 的 集成 组 件 ,包含 在 Windows Server 的 安装 光盘 中 ,但 在 安装 
Windows Server 时 不 会 自动 安装 到 系统 中 。 因 此 , 若 需 安 装 IIS, 需 首先 把 对 应 版 本 的 
Windows Server 安装 光盘 放 到 服务 器 的 光驱 中 ,然后 利用 【控制 面板 ] 中 [添加 /删除 程序 】 
的 [Windows 组 件 ] 管 理 功能 安装 对 应 版 本 的 IIS。 

2. lIS 服务 器 的 相关 概念 

1) 虚拟 目录 

理论 上 讲 , 开 发 者 可 以 把 自己 开发 的 网 页 发 布 到 服务 器 的 任何 文件 夹 中 ,但 发 布 网 页 的 
文件 夹 必须 统一 接受 IIS 的 管理 , 即 发 布 网 页 的 文件 夹 必须 在 逻辑 上 隶属 于 Web 服务 器 ， 
成 为 其 管理 下 的 一 个 目录 。 为 此 ,需要 在 Web 服务 器 下 做 一 个 对 实际 文件 夹 的 映射 ,这 个 


开发 工具 


DBMS 


操作 系统 
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映射 就 是 虚拟 目录 。 例 如 ,实际 的 文件 夹 D:\xyglxt 可 以 映射 为 Web 服务 器 下 的 bnuxy， 
这 个 bnuxy 就 是 一 个 虚拟 目录 ,因为 它 不 是 服务 器 上 实际 存在 的 文件 夹 。 

使 用 虚拟 目录 有 许多 优势 ,主要 表现 如 下 。 

(1) 对 远程 访问 者 屏蔽 真正 的 文件 夹 ,使 远程 用 户 只 能 通过 虚拟 目录 访问 网 页 ,提高 了 
安全 性 ,简化 了 操作 。 

(2) 设置 远程 用 户 对 虚拟 目录 的 访问 权限 。 

(3) 限制 能 够 访问 此 虚拟 目录 的 客户 机 ,把 使 用 某 些 IP 地 址 的 客户 机 拦截 在 系统 之 
外 ,杜绝 一 些 非法 访问 。 

(4) 可 以 设置 虚拟 目录 的 默认 文档 ,把 远程 用 户 对 虚拟 目录 的 访问 转变 成 对 虚拟 目录 
下 特定 文件 的 访问 。 

2) 文件 映射 

JIS 服务 器 对 存储 在 虚拟 目录 下 的 文档 提供 两 种 方式 的 服务 : 其 一 ,直接 把 文件 内 容 发 
送 到 访问 者 的 浏览 器 中 ,例如 各 种 静态 网 页 和 文件 下 载 ; 其 二 ,对 于 某 些 特定 的 程序 , 先 在 
服务 器 端 执行 ,然后 把 执行 结果 发 送 到 访问 者 的 浏览 器 中 ,例如 各 种 ASP、ASP. NET 程序 
和 JSP 程序 。 

在 IIS 服务 器 中 有 一 张 文 件 映射 表 , 用 于 标记 哪些 类 型 的 文档 是 需要 在 服务 器 端 解 释 
运行 的 ,并 标记 了 支持 其 运行 的 动态 链接 库 。 从 理论 上 讲 ,文件 映射 表 包 含 的 文件 类 型 越 
多 ,Web 服务 器 支持 运行 的 能 力 就 越 强 。 然 而 在 MIS 设计 实践 中 ,往往 需要 屏蔽 不 必要 的 
文件 映射 ,因为 文件 映射 能 力 越 强 ,给 远程 攻击 提供 的 机 会 也 越 大 。 

3) 访问 权限 

对 于 IIS 服务 器 下 的 每 个 虚拟 目录 ,都 可 以 设置 远程 用 户 对 它 的 访问 权限 。 其 中 “ 读 
取 ” 权 限 指 远程 访问 者 只 能 读 取 该 虚拟 目录 下 的 文档 ,是 最 基本 权限 ,常常 赋予 存放 静态 网 
页 的 虚拟 目录 ;“ 运 行 脚本 ”权限 允许 远程 访问 者 启动 并 执行 某 些 脚 本 程序 ,ASP 程序 就 应 
存储 在 具有 “运行 脚本 ”权限 的 虚拟 目录 中 。 如 果 希 望 远 程 用 户 能 够 获得 该 虚拟 目录 中 所 有 
文件 的 名 称 列表 并 可 以 任意 下 载 这 些 文件 , 则 可 以 给 予 虚拟 目录 “目录 浏览 ”的 权限 ; 如 果 
允许 远程 用 户 向 此 虚拟 目录 中 任意 上 传 文档 , 则 给 予 * 写 入 ”权限 。 

注意 : 如 果 服 务 器 的 文件 系统 采用 的 是 NTFS 格式 ,那么 虚拟 目录 的 最 终 访问 权限 还 
受到 Windows 对 该 文件 夹 访问 权限 的 影响 ,例如 ,如 果 bnuxy 对 应 的 实际 文件 夹 
D:\xyglxt 在 NTFS 方 案 中 被 设置 为 “'everyone' 没 有 任何 权限 ”, 那 么 即使 已 经 对 虚拟 目录 
bnuxy 设置 了 “ 读 取 ”和 “执行 脚本 ”的 权限 ,远程 用 户 仍 无 权 访 问 此 虚拟 目录 。 


(2,2 1IS 服务 器 的 安装 与 配置 


本 节 将 以 Windows Server 2003 和 Windows 7 为 例 ,简要 介绍 IIS 组 件 的 安装 与 配置 
过 程 。 
12.2.1 IS 6.0 服务 器 的 安装 与 配置 


1. lIS 6.0 服务 器 安装 
启动 Windows Server 2003 的 【控制 面板 ,打开 【添加 /删除 程序 窗口 ,选择 [添加 / 删 


动态 网 站 设计 与 开发 (ASP. NET 版 ) 


除 Windows 组 件 ], 打 开 [Windows 组 件 向 导 】 对 话 框 , 如 图 12-1 所 示 。 
选择 [应 用 程序 服务 器 】, 然 后 单 击 【详细 信息 按钮 ,打开 【应 用 程序 服务 器 ] 对 话 框 ,如 
图 12-2 所 示 。 


本 
Tindors 组 件 Fs 
可 以 添加 或 册 除 Windows 的 组 件 。 | 
| 可 
和 证 RR te 
Sp ee 
姐 件 忆 ) 
辑 葡 Internet 信息 服务 CTS) 18.2 加 
加 泡 避 用 同 癌 com 访问 0.0m 
口 欧 有 用 RDTc 访问 0.0 上 
口 轧 运程 半 服务 18 皮 口 世 消息 队列 4.5 
口号 远 村 Pe 也 从 可 用 程 订 服 务 器 辽 制 台 oom 司 
描述 ; 篇 ASP. 了 ET ，Internet 信息 服务 (IS) 和 应 用 程序 服务 器 近 制 撕 述 ， 允许 此 计算 机 运行 ASP. JET 应 用 程序 。 
所 需 磅 甸 空 间 .1 虑 
可 用 山 生 宝 间 ; 4322.8 虑 
所 看 磁 生 空间 2.1 妥 a 
可 用 而 多 空间 4322.8 用 Eis 
《上 一步 人 | 下 一 步 人 D> 取消 攻防 取消 
12-1 在 Windows Server 2003 中 启动 图 12-2 在 IIS 6.0 应 用 程序 服务 器 安装 过 程 中 
“IIS 6.0 安装 ” 选择 安装 组 件 


选择 ASP.NET, 可 以 使 此 服务 器 支持 ASP.NET 运行 。 

选择 【Internet 信息 服务 (IIS)】, 使 [Internet 信息 服务 (IIS)】 复 选 框 生效 。 然 后 单 击 【 详 
细 信 息 ] 按 钮 ,在 Internet 信息 服务 (JIS) 的 详细 信息 中 选择 【万 维 网 服务 了 ,然后 再 次 单 击 
【详细 信息 了 按钮 ,在 这 个 界面 内 选中 Active Server Pages, 保 证 IIS 服务 器 能 够 支持 ASP 程 
序 的 运行 。 

设置 完毕 , 单 击 若干 次 [确定 按钮 , 回 到 【Windows 组 件 向 导 】 对 话 框 ,然后 单 击 【 下 一 
步 按 钮 ,就 开始 在 服务 器 上 安装 IIS 服务 了 。 

系统 安装 完毕 ,会 在 服务 器 上 建立 一 个 名 称 为 Inetpub 的 子 文件 夹 ,其 下 有 wwwroot、 
ftproot 等 文件 夹 。 其 中 ,wwwroot 是 Web 服务 器 的 根 文件 夹 ,ftproot 是 FTP 服务 器 的 根 
文件 夹 。 

通常 ,可 以 把 一 个 文本 文件 复制 到 wwwroot 文件 夹 下 ,然后 在 I 下 浏览 器 的 地 址 栏 中 输 
人 “http://127.0.0.1/ 文 本 文件 名 . txt? 并 回 车 ,通过 在 下 界面 下 能 否 显示 出 此 文本 文件 
的 内 容 来 检测 IIS 安装 是 否 成 功 。 

注意 ; 是 否 在 安装 JIS 时 安装 ASP .NET 组 件 ,取决 于 项 目的 应 用 系统 。 如 果 计 划 以 
ASP.NET 开发 MIS, 则 安装 ASP .NET 组 件 。 如 果 计 划 以 ASP 开发 系统 , 则 一 定 不 要 安 
装 ASP.NET 组 件 。 

2. 配置 IIS 6.0 服务 器 的 虚拟 目录 

安装 IIS 服务 后 ,将 会 在 【控制 面板 】 的 【管理 工具 】 中 创建 命令 项 【Internet 信息 服务 
(IIS) 管 理 器 〗, 所 有 的 IIS 配置 工作 都 由 [Internet 信息 服务 (JIS) 管 理 器 】 负 责 。 下 面 将 以 红 
星 中 学 校友 信息 系统 的 建设 为 例 说 明 IIS 6. 0 服务 器 虚拟 目录 的 配置 。 

已 知 红星 中 学 服务 器 的 IP 地 址 为 202. 112. 94. 36 ,服务 器 上 已 经 正确 地 安装 了 IIS ,并 
配置 了 相应 版 本 的 .NET Framework 框架 。 现 在 学 校 以 ASP.NET 开发 了 一 套 校友 信息 管 
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理 系统 ,系统 的 主 文件 名 为 index. aspx。 校 长 要 求 配置 Web 服务 器 ,希望 能 够 通过 
“http://202. 112. 94. 36/xyxt/ ”访问 校友 信息 管理 系统 。 

由 于 Web 服务 器 的 IIS 已 经 完成 安装 ,而 且 也 完成 了 网 络 配 置 ,因此 本 案例 的 目标 是 
设置 一 个 能 够 执行 aspx 程序 的 虚拟 目录 xyxt, 并 把 此 虚拟 目录 的 默认 文档 设置 为 index 
.aspx, 具 体 的 操作 过 程 如 下 。 

1) 创建 存放 校友 系统 的 实际 文件 夹 

在 D 盘 的 根 目 录 处 创建 一 个 新 文件 夹 ,命名 为 hxxygl, 即 D:\hxxygl。 检 查 D 盘 的 文 
件 系 统 , 如 果 是 NTFS 格式 , 则 需要 检查 D:\hxxygl 的 操作 权限 ,设置 “everyone” 组 具有 读 
取 权 限 。 

2) 映射 虚拟 目录 

(1) 通过 [开始 ]>【 控 制 面板 >【 管 理工 具 】>【Internet 信息 服务 (IIS) 管 理 器 】 直 接 启 
动 IIS 配置 工具 。 此 窗口 由 两 部 分 组 成 , 左 侧 是 一 个 树 状 层次 结构 , 右 侧 为 主 工作 区 。 单 击 
小 “十 "号 展开 左 侧 的 树 结构 中 的 分 支 , 选 择 【默认 网 站 】 ,将 在 右 侧 窗口 中 展开 当前 的 Web 
服务 器 的 目录 结构 ,如 图 12-3 所 示 。 


Internet 信息 服务 IIS) 管理 器 
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12-3 IIS 6.0 信息 服务 管理 器 的 主 界面 


(2) 右 击 “默认 网 站 ”( 或 者 在 右 侧 窗口 的 空白 处 右 击 ) ,在 弹出 的 快捷 菜单 中 选择 【新 
建 ]>【 虚 拟 目 录 】, 打 开 【[ 虚 拟 目 录 创 建 向 导 】 对 话 框 。 

(3) 先 给 要 建立 的 虚拟 目录 起 个 名 字 , 把 它 填 人 别名 栏目 中 。 本 例 中 输入 “xyxt”, 如 
图 12-4 所 示 。 

(4) 单 击 [ 下 一 步 ] 按 钮 后 ,系统 要 求 说 明 虚 拟 目 录 对 应 的 实际 文件 夹 名 称 。 直 接 输入 
本 地 硬盘 上 的 指定 文件 夹 名 称 “D:\hxxygl”, 或 者 利用 [浏览 按钮 选 定 “D:\hxxygl”, 如 
图 12-5 所 示 。 

(5) 选 定 文件 夹 或 输入 文件 夹 名 称 后 , 单 击 【 下 一 步 ] 按 钮 ,进入 设置 虚拟 目录 [访问 权 
限 了 的 对 话 框 ,如 图 12-6 所 示 。 通 过 设置 复 选 框 限制 远程 用 户 使 用 此 虚拟 目录 的 权限 。 因 
为 本 例 中 的 虚拟 目录 要 存放 ASP 脚本 文件 , 则 给 予 “ 运 行 脚本 ”权限 。 为 保证 系统 的 安全 
性 ,不 要 给 虚拟 目录 xyxt* 浏 览 " 和 “ 写 入 ”权限 。 

(6) 设置 完毕 , 单 击 【下 一 步 ] 按 钮 完成 设置 。 此 时 已 经 完成 了 虚拟 目录 xyxt 对 文件 夹 
D:\hxxygl 的 映射 ,存储 D: \hxxygl 下 的 文件 可 以 被 远程 用 户 通过 “http://202. 112. 94. 
36/xyxt/ 文 件 名 称 ” 访 问 。 
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图 12-4 为 虚拟 目录 设置 别名 图 12-5 指定 虚拟 目录 对 应 的 实际 文件 夹 


3) 设置 默认 文档 

(1) 完成 虚拟 目录 的 配置 后 ,远程 用 户 已 经 可 以 通过 “http://202. 112. 94. 36/xyxt/ 文 
件 名 称 ” 访 问 D:\hxxygl 下 的 文件 了 。 但 当 远 程 用 户 在 自己 的 下 地 址 栏 输 入 “http://202. 
112. 94. 36/xyxt/”(URL 中 没有 文件 名 ,只 有 虚拟 目录 名 称 ) 时 ,这 时 会 因为 URL 中 没有 文 
件 名 而 且 虚 拟 目 录 xyxt 也 没有 设置 默认 文档 而 提示 “网 页 无 法 打开 ”或 者 “无 权 浏览 目录 ”。 
此 时 ,应 该 把 Default. aspx 设置 为 此 虚拟 目录 的 默认 文档 。 

(2) 在 [Internet 信息 服务 (IIS) 管 理 器 中 , 右 击 刚刚 建 好 的 虚拟 目录 “xyxt”, 在 弹出 的 
快捷 菜单 中 选择 [属性 】 ,打开 【xyxt 属性 ] 对 话 框 。 选 中 “文档 ”选项 卡 ,启动 如 图 12-7 所 示 
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图 12-6 设置 虚拟 目录 的 操作 权限 图 12-7 设置 虚拟 目录 的 默认 文档 ( 首 个 网 页 ) 


(3) 单 击 [ 添 加 按钮 ,把 Default. aspx 添加 到 中 上 部 的 列表 框 中 。 然 后 选中 Default 
.aspx 文 件 , 单 击 【 上 移 ] 按 钮 ,使 Default. aspx 处 于 第 一 的 位 置 。 

4) 测试 虚拟 目录 配置 

用 FrontPage 或 Dreamweaver 设计 一 个 内 容 非 常 简单 的 网 页 文件 index. asp, 然 后 把 
此 文件 复制 到 D:\hxxygl 中 , 即 把 index. asp 复制 到 虚拟 目录 xyxt 对 应 的 实际 文件 夹 
D:\hxxygl 中 。 
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到 另外 一 台 已 经 接 入 Internet 的 计算 机 上 ,启动 IE 浏览 器 ,在 其 地 址 栏 中 输入 
“http://202. 112. 94. 36/xyxt” 并 按 回 车 后 ,检查 能 否 看 到 index. asp 的 内 容 。 如 果 能 够 看 
到 index. asp 的 内 容 , 则 说 明 虚 拟 目 录 xyxt 的 配置 正确 ,就 可 以 把 红星 中 学 的 校友 信息 管 
理 系统 复制 到 D:\hxxygl 中 了 。 

3. 1IS 的 优化 与 安全 配置 

JIS 是 微软 的 操作 系统 中 漏洞 比较 多 的 一 个 组 件 ,又 因为 IIS 主要 用 于 存储 网 页 文件 ， 
供 Internet 用 户 通过 浏览 器 访问 ,因此 IIS 配置 不 当 , 将 会 给 系统 留 下 巨大 隐患 。 为 降低 黑 
客 通过 IIS 攻击 系统 的 概率 ,一 般 不 建议 使 用 系统 的 默认 配置 。 

1) 修改 IIS 默认 的 文档 配置 

由 于 IIS 默认 的 文档 位 置 (CC:\Inetpub 或 D:\Inetpub) 众 所 周知 ,因此 采用 默认 位 置 存 
放 MIS 隐患 很 多 。 因 此 ,建议 在 其 他 驱动 器 上 建立 另外 的 文件 夹 作为 IIS 的 主 文档 ,并 修改 
必要 的 配置 信息 。 

例如 ,在 下 盘 上 建立 一 个 文件 夹 WWWPUB, 然 后 启动 【Internet 信息 服务 (I1IS) 管 理 
器 】。 右 击 【默认 网 站 】 ,选择 [属性 】 ,打开 如 图 12-8 所 示 的 [默认 网 站 属性 ] 对 话 框 。 

接着 选择 [ 主 目录 选项 卡 ,然后 把 主 目录 对 应 的 位 置 修改 为 E:\WWWPUB。 

另外 ,IIS 自 带 的 “远程 Web 服务 管理 器 ”和 “Scripts” 虚 拟 目 录 等 在 为 站 点 管理 者 提供 
远程 管理 的 便利 之 时 ,也 为 系统 安全 留 下 了 隐患 。 因 此 ,如 果 不 是 非常 需要 对 Web 站 点 实 
施 远程 管理 , 则 删除 这 些 不 必要 的 虚拟 目录 。 

2) 不 轻易 开通 FTP 上 传 服务 ,不 允许 用 户 匿名 浏览 Web 目录 

为 了 避免 不 必要 的 版 权 纠纷 ,避免 别有用心 的 用 户 向 Web 服务 器 中 上 传 恶意 代码 。 
JIS 服务 器 一 般 不 开通 FTP 上 传 服务 ,也 不 允许 匿名 用 户 浏览 Web 站 点 目录 。 因 为 如 果 允 
许 匿名 用 户 浏览 Web 站 点 中 的 某 目录 ,远程 用 户 就 有 可 能 下 载 这 个 虚拟 目录 中 的 源 程序 ， 
通过 分 析 源 代码 找到 攻击 系统 的 方法 。 修 改 虚 拟 目录 访问 权限 的 具体 操作 为 如 下 。 

启动 [Internet 信息 服务 管理 器 】, 选 择 管理 中 的 Web 站 点 ,例如 选择 【默认 网 站 】。 在 
展开 默认 网 站 的 树 状 层次 结构 后 , 右 击 某 一 虚拟 目录 , 选 【属性 】, 则 打开 了 此 虚拟 目录 的 属 
性 设置 对 话 框 。 例 如 选择 了 “xyxt”, 其 属性 对 话 框 如 图 12-9 所 示 。 
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通过 中 部 区 域 的 “ 读 取 ”“ 写 人 ”“ 目 录 浏 览 ” 等 复 选 框 ,底部 的 “执行 权限 ”下 拉 列 表 框 
可 以 设置 远程 普通 用 户 对 这 个 虚拟 目录 的 操作 权限 。 

注意 : 除非 特殊 需要 ,一 般 不 要 给 Web 虚拟 目录 “ 写 入 ”“ 目 录 浏 览 " 和 “执行 权限 ”。 

除非 特殊 需要 ,一 般 不 允许 匿名 用 户 向 FTP 目录 上 传 文件 。 另 外 ,尽量 避免 允许 用 户 
直接 向 Web 虚拟 目录 中 上 传 可 执行 文件 。 

3) 限制 外 部 访问 者 的 IP 地 址 

有 些 动态 网 站 只 允许 特定 范围 的 人 员 访 问 ,需要 从 网 络 连接 的 层面 对 外 部 用 户 进行 约 
束 。 为 解决 这 一 问题 ,通常 借助 IIS 限制 访问 者 IP 地 址 的 技术 ,只 允许 特定 的 IP 地 址 访问 
此 虚拟 目录 ,具体 操作 步骤 如 下 。 

(1) 启动 [Internet 信息 服务 管理 器 】, 选 中 需要 限制 访问 者 的 那个 虚拟 目录 , 右 击 后 选 
择 [ 属 性 】 ,打开 虚拟 目录 [属性] 对 话 框 ,如 图 12-9 所 示 。 

(2) 单 击 【目录 安全 性 标签 ,进入 【 目 录 安 全 性 〗 选 项 卡 ,如 图 12-10 所 示 。 

(3) 在 【目录 安全 性 】 选 项 卡 中 , 单 击 栏目 【IP 地 址 和 域名 限制 ] 中 的 按钮 [编辑 】 ,打开 
【IP 地 址 和 域名 限制 ] 对 话 框 ,如 图 12-11 所 示 。 
[E222 
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图 12-10 设置 虚拟 目录 的 目录 安全 性 图 12-11 【IP 地 址 和 域名 限制 ] 对 话 框 


(4) 如 果 仅 有 某 几 台 计 算 机 不 能 访问 此 虚拟 目录 ,其 他 计算 机 都 可 以 访问 这 个 虚拟 目 
录 , 则 可 以 选择 [授权 访问 ] 单 选 按钮 ,然后 单 击 【添加 3 按钮 ,把 不 能 访问 此 虚拟 目录 的 用 户 
IP 地 址 逐个 添加 进来 ; 反之 ,如 果 只 允许 某 几 台 计 算 机 访问 这 个 虚拟 目录 ,其 他 计算 机 都 不 
能 访问 此 虚拟 目录 ,就 选择 [拒绝 访问 了 单 选 按钮 ,然后 单 击 [ 添 加 按钮 ,把 可 以 访问 本 虚拟 
目录 的 IP 地 址 逐个 添加 进来 。 如 果 要 添加 的 IP 地 址 很 多 ,而 且 有 一 定 的 规律 ,还 可 以 在 添 
加 过 程 中 使 用 子 网 掩 码 ,一 次 把 一 个 子 网 段 的 IP 地 址 添加 进来 。 

图 12-11 所 示 的 就 是 只 有 两 个 IP 地 址 可 以 访问 该 虚拟 目录 的 情况 。 

4) 配置 IIS 的 用 户 验证 方式 

通常 , Web 应 用 程序 系统 可 支持 多 种 验证 方式 。 其 中 最 常见 的 两 种 方式 为 Forms 验证 
和 Windows 集成 验证 。 所 谓 Windows 集成 验证 ,就 是 利用 Windows 服务 器 的 内 置 账户 进 
行 用 户 身份 验证 ,使 所 有 已 在 Windows Server 上 注册 的 ,能够 访问 Windows 服务 器 的 用 户 
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都 可 以 访问 此 Web 服务 器 。 由 于 这 种 方式 仅 允许 已 经 在 Windows Server 上 注册 的 账户 或 
者 隶属 于 此 Windows 域 的 用 户 访问 Web 系统 ,能 够 和 Windows 的 其 他 服务 密切 地 结合 
来 ,是 一 种 适合 小 型 机 构 内 部 ,在 局 域 网 范围 内 集中 办 公 的 单位 采用 的 身份 验证 方式 。 

如 果 需 要 启动 Windows 集成 身份 验证 ,只 须 进 行 如 下 配置 。 

(1) 在 【目录 安全 人 性] 选项 卡 下 , 单 击 【 身 份 验证 和 访问 控制 ] 栏 目 中 的 [编辑 ] 按 钮 ,启动 
身份 验证 编辑 状态 ,打开 [身份 验证 方法 ] 对 话 框 ,如 图 12-12 所 示 。 

(2) 撤销 【启用 匿名 访问 ] 复 选 框 ,使 匿名 用 户 无 法 访问 本 Web 服务 器 。 

(3) 选中 [集成 Windows 身份 验证 ] 复 选 框 ,使 IIS 服务 器 可 以 借助 Windows 的 账户 体 
系 , 从 而 使 得 凡 在 Windows Server 上 注册 过 的 用 户 都 可 以 便利 地 通过 Windows 账号 和 密 
人 码 访问 此 Web 服务 器 。 

注意 :“ 集 成 Windows 身份 验证 ”是 一 种 利用 Windows 自身 的 用 户 控制 功能 来 实现 
Web 用 户 身份 验证 的 方式 。 用 户 对 Web 应 用 系统 文件 夹 中 信息 的 访问 要 受到 NTFS 文件 
系统 授权 的 影响 。 如 果 某 一 Windows 用 户 没有 读 取 Web 应 用 程序 所 在 文件 夹 或 者 数据 库 
文件 的 权力 ,那么 他 对 Web 服务 器 的 访问 将 会 被 拒绝 。 

5) 取消 不 必要 的 文件 映射 

作为 一 个 功能 强大 的 Web 服务 器 ,IIS 支持 很 多 脚本 文件 和 CGI 程序 。 作 为 一 个 支持 
MIS 的 平台 来 讲 ,IIS 只 须 解析 MIS 所 需 的 几 种 文件 类 型 。 为 了 避免 黑客 利用 那些 对 MIS 无 
用 的 脚本 类 型 攻击 系统 ,建议 在 IIS 管理 器 中 删除 任何 无 用 的 文件 映射 。 具 体操 作 方法 如 下 。 

(1) 启动 【Internet 信息 服务 (IIS) 管 理 器 】, 选 中 具有 执行 脚本 权限 的 特定 虚拟 目录 , 右 
击 后 选择 [属性 】, 打 开 虚 拟 目录 属性 设置 对 话 框 ,如 图 12-9 所 示 。 

(2) 单 击 对 话 框 底部 的 [配置 ] 按 钮 (如 果 虚 拟 目 录 有 执行 权限 ,【 配 置 ] 按 钮 就 不 是 灰色 
的 ) ,打开 【应 用 程序 配置 ] 对 话 框 ,选中 映射] 选项 卡 。 如 图 12-13 所 示 。 
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图 12-12 设置 Windows 集成 身份 验证 方式 图 12-13 【应 用 程序 配置 ] 对 话 框 


(3) 把 不 需要 的 文件 类 型 逐个 小 心地 删除 ,最 后 单 击 [ 确 定 了 按钮 ,确认 刚才 的 操作 。 
6) 去 除 利 用 "程序 报错 ?窃取 服务 器 基本 信息 的 可 能 
有 些 高 级 黑客 能 够 通过 脚本 程序 报错 信息 得 知 服务 器 的 版 本 、 性 能 .补丁 状况 ,而 这 些 
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信息 就 成 为 他 们 攻击 系统 的 基础 资料 。 因 此 ,这 种 为 开发 人 员 调 试 程序 准备 的 报错 信息 也 
可 能 成 为 系统 安全 的 隐患 。 所 以 ,对 于 运行 中 的 工作 服务 器 ,应 该 关闭 程序 报错 信息 。 

去 除 准确 “程序 报错 ?功能 的 具体 操作 步骤 如 下 。 

(1) 打开 【Internet 信息 服务 管理 器 】, 选 中 具有 执行 脚本 权限 的 某 个 虚拟 目录 , 右 击 后 
选择 [属性 】 ,打开 虚拟 目录 属性 设置 对 话 框 ,如 图 12-9 所 示 。 

(2) 单 击 对 话 框 底 部 的 【配置 按钮 (如 果 虚 拟 
目录 有 执行 权限 ,【 配 置 ] 按 钮 就 不 是 灰色 的 ), 打 
开 【 应 用 程序 配置 ] 对 话 框 ,选中 [调试] 选项 卡 ,如 
图 12-14 所 示 。 

选中 [向 客户 端 发 送 下 列 文本 错误 消息 ] 单 选 
按钮 ,然后 在 下 面 的 文本 框 中 输入 一 些 特殊 文字 ， 
从 而 使 IIS 不 会 把 系统 的 完整 报错 信息 发 送 给 远 
程 用 户 ,以 免 远程 用 户 利 用 报错 信息 窃取 服务 器 
版 本 信息 等 资料 。 最 后 单 击 【确定 按钮 确认 刚才 
的 操作 。 图 12-14 设置 调试 信息 显示 方式 

7) 不 允许 客户 在 留言 中 包含 控制 字符 

现在 很 多 MIS 利用 ASP、JSP 等 脚本 语言 设计 系统 讨论 组 、 系 统 留 言 板 。 如 果 系 统 把 
收 到 的 留言 信息 不 作 任 何 处 理 就 直接 存 人 后 台数 据 库 ,那么 远程 黑客 就 可 以 通过 在 留言 板 
中 书写 带 有 控制 功能 的 字符 串 , 通 过 让 系统 运行 这 些 特殊 的 字符 串 获取 系统 信息 ,从 而 达到 
控制 系统 的 目的 。 因 此 ,如 果 系 统 中 开设 了 留言 板 服务 ,那么 在 把 留言 信息 保存 或 发 布 之 前 
一 定 要 过 滤 掉 用 户 留言 中 的 控制 符号 。“ 过 二 ”“ 过 % …% 二 ”、 单 双 引 号 等 符号 都 必须 滤 
掉 或 用 其 他 符号 代替 。 否 则 ,恶意 的 用 户 很 可 能 利用 留言 板 发 布 恶 意 代码 ,并 通过 留言 板 运 
行 它 , 进 而 达到 他 不 可 告 人 的 目的 。 

8) 限制 用 户 上 传 包含 可 执行 脚本 的 文件 

如 果 Web 服务 器 允许 上 传 执行 含有 可 执行 脚本 的 文件 , 则 可 能 给 系统 带 来 巨大 隐患 。 
因此 应 该 限制 用 户 上 传 包含 可 执行 脚本 的 文件 。 如 果 必 须 允 许 用 户 上 传 ASP、ASPX 或 
PHP 等 可 执行 的 脚本 文件 ,那么 在 服务 器 上 一 定 要 有 严格 的 文件 夹 授权 控制 措施 。 


12.2.2 1IS 7.0 服务 器 的 安装 与 配置 


本 节 以 Windows 7 为 例 ,简要 说 明 IIS 7.0 组 件 的 安装 与 配置 。 

1. IIS 7.0 服务 器 的 安装 

(1) 启动 Windows 7 的 [控制 面板 】, 打 开 【 程 序 ] 选 项 ,从 [程序 和 功能 栏目 下 选择 【 打 
开 或 关闭 Windows 功能 】 ,将 会 打开 如 图 12-15 所 示 的 窗口 。 

(2) 展开 【Internet 信息 服务 】 项 ,选中 【IIS 管理 服务 ] 复 选 框 。 

(3) 展开 【万 维 网 服务 了 项 ,如 图 12-16 所 示 。 在 【安全 性 ] 项 目下 ,至 少 选择 [IP 安全 】、 
【Windows 身份 验证 】【 基 本 身份 验证 】 【客户 端 证 书 映射 身份 验证 ] 项 目 。 在 【常见 HTTP 
功能 项 目下 ,至 少 选择 [HTTP 错误 】 【静态 内 容 】 【默认 文档 〗【 目 录 浏 览 ] 等 项 目 , 否 则 
可 能 导致 IS 7. 0 无 法 正常 工作 。 例 如 ,有 的 用 户 因为 没有 选择 【静态 内 容 】 而 导致 远程 客户 
无 法 浏览 Web 站 点 上 的 静态 网 页 ,甚至 不 能 浏览 最 普通 的 JPG 图 像 内 容 。 


应 用 程序 配置 | 
里 时 | 选项 调式 | 


-- 调 者 
厂 下 用 7 入 有 下 清二 ] 
厂 启用 /sp 客户 疫 本 酒 二 中 
一 脚本 精 识 的 本 识 消 息 
请 客 户 靖 发送 详细 的 1S 铺设 消息 G) 
玉 向 客户 靖 改 送 下 列 文 本 博识 潭 息 了) 


第 12 章 “Web 服务 器 与 网 页 发 布 


二 关闭 Windows 功能 © 
车 要 打开 一 种 功能 ， 请 ) 先 择 其 复 迁 框 。 若 要 关闭 一 种 功能 ， 请 清除 其 复 迁 
框 。 填 充 的 框 表示 仅 打开 该 功能 的 一 部 分 . 


回 易 Internet Information Services 可 入 载 的 Web 核心 
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图 12-15 安装 IIS 7. 0 时 选择 组 件 的 窗口 图 12-16 安装 TIS 7.0 时 配置 “安全 性 ?和 
“HTTP 功能 ”组 件 


(4) 展开 【应 用 程序 开发 功能 ] 项 ,可 根据 需要 选中 ASP.NET【.NET 扩展 ] 等 项 目 ,如 
图 12-17 所 示 。 

(5) 如 果 要 安装 的 功能 已 经 配置 完毕 ,就 单 所 
击 右 下 角 的 【确定 】 按 钮 ,系统 开始 自动 从 | 5jpsgxy windows 功 能 
Windows 7 的 安装 盘 上 复制 相关 文件 ,并 完成 基 | stow 下 Iie 
础 配置 。 

2. lIS 7.0 服务 器 的 配置 

与 IIS 6.0 相似 ,在 IIS 7. 0 安装 完毕 ,会 
服务 器 系统 盘 上 建立 一 个 名 称 为 Inetpub 的 子 
文件 夹 ,其 下 有 wwwroot、ftproot 等 文件 夹 。 其 


中 ,wwwroot 是 Web 服务 器 的 根 文件 夹 ， Re 
ftproot 是 FTP 服务 器 的 根 文件 夹 。 通 常情 况 -i 
下 ,人 们 会 在 下 的 地 址 栏 中 输入 “http://127. ee 
0.0. 1/iisstart. htm” 并 回 车 ,通过 IE 的 反馈 信 口上 服务 吕 江 包 全 
息 来 检测 IIS 安装 是 否 成 功 。 
安装 IIS 7.0 服务 后 ,将 会 在 【控制 面板 了 ~ 图 12-17 安装 IIS 7.0 时 配置 “应 用 程序 
【系统 和 安全 】 的 【管理 工具 】 中 创建 命令 项 开发 功能 "组 件 


“Internet 信息 服务 (11S) 管 理 器 ”, 所 有 的 IIS 配 
置 工作 都 由 “Internet 信息 服务 (JIS) 管 理 器 ”负责 。 
启动 【Internet 信息 服务 (IIS) 管 理 器 】, 其 操作 界面 如 图 12-18 所 示 。 
1) 新 建 网 站 
在 【Internet 信息 服务 (IIS) 管 理 器 】 中 , 右 击 树 状 结构 图 中 的 【网 站 选项 ,在 弹出 的 菜单 


306%” 动态 网 站 设计 与 开发 (ASP. NET 版 ) 


GO [0 wc, me , oweb se, 


12-18 Internet 信息 服务 (IIS) 管 理 器 的 主 界面 


中 选择 [添加 网 站 】, 则 打开 [添加 网 站 】 对 话 框 ,如 图 12-19 所 示 。 利 用 此 对 话 框 可 以 创建 一 


个 新 的 网 站 。 图 12-19 中 就 新 建 了 一 个 网 站 ,网 站 名 称 为 “教学 系统 ”、 网 站 的 物理 路 径 是 
F:\Ma, 而 且 网 站 绑 定 了 本 机 上 的 一 个 IP 地址 192. 168. 0. 2 ,访问 端口 是 80。 


Rss aa 
教学 系统 教学 系统 
内 容 目 录 
和 9 小 各: 

FAMa 四 
传闻 身份 验证 
RQ- | | at 本 G)- | 
[WRG 
证 
ED: 信 地址 D: al 
tp "| ED 0 
Ea 
示 作 www.contoso.com 或 marketing.contoso.com 
国立 加 B 动 由 M) 
确定 取消 


12-19 利用 IIS 7.0 管理 器 添加 网 站 的 主 界面 


如 果 使 用 80 以 外 的 端口 为 特定 网 站 服务 ,要 注意 不 能 使 用 TCP/IP 协议 中 已 经 内 定 了 
的 ,特定 用 途 的 端口 (如 53、110、21、23、25 等 ) ,可 以 使 用 4000 一 10 000 之 间 的 任意 端口 ,并 
且 要 让 防火 墙 开 放 这 些 端 口 。 
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由 于 HTTP 协议 的 默认 端口 为 80, 所 以 如 果 绑 定 了 80 以 外 的 其 他 端口 , 则 在 以 正 访 
问 本 网 站 时 ,必须 使 用 HTTP:// 了 地址 ?或 “域名 :端口 号 /路 径 /主页 文件 名 ”格式 指明 端 
口号 。 

注意 : 网 站 使 用 的 IP 地 址 必须 是 服务 器 已 经 配置 的 IP 地 址 ,而 且 支持 远程 访问 ; 不 允 
许多 个 网 站 使 用 相同 的 IP 地 址 且 使 用 相同 的 端口 。 如 果 需 要 在 一 个 IP 地 址 下 绑 定 多 个 网 
站 , 则 可 以 分 别 绑 定 到 不 同 的 端口 上 。 

2) 新 建 虚拟 目录 

在 【Internet 信息 服务 (JIS) 管 理 器 】 中 , 右 
击 树 状 结构 图 中 的 某 一 个 网 站 或 者 某 个 文件 
来 ,在 弹出 的 菜单 中 可 以 选择 【添加 虚拟 目录 】 
选项 ,系统 会 打开 【添加 虚拟 目录 】 对 话 框 ,如 
图 12-20 所 示 。 

在 【添加 虚拟 目录 对 话 框 下 ,可 以 把 本 地 
磁盘 上 的 任意 一 个 文件 夹 设置 一 个 别名 ,使 之 
成 为 当前 网 站 下 的 一 个 子 目 录 , 使 远程 用 户 可 
以 访问 此 目录 下 的 文件 。 

3) 设置 IP 地 址 或 域名 限制 

对 于 本 服务 器 上 的 网 站 (虚拟 目录 ), 可 以 图 12-20 利用 TS 7.0 添加 虚拟 目录 的 对 话 杠 
设置 IP 地址 限制 或 域名 限制 ,设置 为 只 允许 某 
些 IP 地 址 的 计算 机 可 访问 ,或 者 设置 为 “除了 特定 的 一 些 计算 机 ,其 他 计算 机 都 可 访问 此 网 
站 (或 虚拟 目录 )”。 具 体 设置 方法 如 下 。 

(1) 从 [Internet 信息 服务 (IIS) 管 理 器 窗口 左 侧 的 目录 树 中 选 定 需要 进行 设置 的 网 站 
(或 虚拟 目录 ) ,接着 在 中 部 区 域 选择 【IP 地 址 或 域 限制 】〗, 然 后 从 右上 角 选 择 【[ 打 开 功 能 】, 系 
统 会 弹出 如 图 12-21 所 示 的 窗口 。 


TIE 下 


© | Em A 
配置: “localhost” applicationHost.config , <location path="Default Web Site/aspnet_client/jxhd"> bE 


图 12-21 设置 虚拟 目录 允许 /拒绝 的 IP 地 址 
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(2) 在 此 窗口 中 ,利用 右上 角 的 【添加 允许 条 目 】 或 【添加 拒绝 条 目 ] 可 以 设置 被 允许 或 
被 拒绝 的 IP 地 址 ,甚至 是 带 有 子 网 掩 码 的 了 P 地址 组 。 

4) 设置 默认 主页 

对 于 一 个 网 站 (或 虚拟 目录 ) ,通常 需要 设置 一 个 默认 网 页 ,作为 这 个 网 站 的 主页 。 当 网 
站 的 默认 主页 设置 成 功 后 ,用 户 在 访问 此 站 点 时 ,只 需 在 IE 地 址 栏 中 输入 站 点 的 IP 地 址 或 
域名 (或 虚拟 目录 名 ) ,不 必 输 入 首 个 文件 名 ,能 够 提高 用 户 的 浏览 效率 和 网 站 的 人 性 化 
水 平 。 

要 设置 站 点 (或 虚拟 目录 ) 的 默认 主页 ,只 须 首先 从 【Internet 信息 服务 (IIS) 管 理 器 】 
窗口 左 侧 的 目录 树 结构 中 选中 站 点 (或 虚拟 目录 ) ,接着 从 中 部 的 IIS 栏 目下 选择 [默认 文 
档 】, 然 后 单 击 右 上 角 的 【打开 功能 ] 超 链接 , 则 打开 设置 [默认 文档 的 窗口 ,如 图 12-22 
所 示 。 


12-22 设置 虚拟 目录 的 默认 文档 (虚拟 目录 的 首 个 网 页 ) 


利用 它 可 添加 或 删除 默认 文档 ,而 且 可 以 利用 右 侧 的 [下 移 ]【 上 移 了 操作 ,调整 各 个 文 
档 的 次 序 。 

5) 设置 目录 浏览 

设置 目录 浏览 是 为 网 站 (或 虚拟 目录 ) 打 开 目 录 浏 览 功 能 。 一 个 网 站 (或 者 虚拟 目录 ) 一 
旦 被 打开 目录 浏览 功能 ,远程 用 户 就 可 以 通过 浏览 器 便利 地 获取 该 网 站 (或 虚拟 目录 ) 的 目 
录 列表 , 并 且 可 通过 此 目录 列表 从 这 个 网 站 (或 虚拟 目录 ) 上 下 载 任意 一 个 文件 。 

如 果 希 望 赋予 某 个 站 点 (或 虚拟 目录 ) 具 备 “ 目 录 浏 览 * 权 限 , 则 首先 从 KInternet 信息 服 
务 (IIS) 管 理 器 窗口 左 侧 的 目录 树 结构 中 选中 站 点 (或 虚拟 目录 ) ,接着 从 中 部 的 IIS 栏目 下 
选择 [目录 浏览 】, 然 后 单 击 右 上 角 的 [打开 功能 ] 超 链接 , 则 打开 设置 [目录 浏览 的 窗口 ,如 
图 12-23 所 示 。 

系统 默认 为 [ 楚 用 目录 浏览 ]。 如 果 要 启动 它 , 只 须 在 图 12-23 的 右 侧 单 击 【启用 】, 就 能 
赋予 选 定 网 站 (或 虚拟 目录 ) 具 有 目录 浏览 权限 。 在 启用 [目录 浏览 ] 后 ,可 以 在 中 部 的 窗口 
中 设置 可 以 显示 在 远程 客户 机 浏览 器 中 的 文件 信息 。 
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a | 

和 | 前 目录 浏览 

| 同 MAXLPC (MAXLPCWnad) | 入 Etnh 能 折 定 时 未 在 有 录 列 下 的 信息 、 | 
地 产 RE5 池 Ee 


4 国 网 5 
4 @ Default Web Site 
4 aspnet client 
jhd 扩展 四 
3 system web 
总 my 
全 区 5 纺 


一 "| vm | 局 me 
配置 "Default Web Site/aspnet_client/jxhd” web.config 得 


12-23 对 虚拟 目录 启用 /禁止 赋予 "目录 浏览 "权限 


注意 : 除非 确实 需要 提供 一 个 专门 用 于 下 载 资 料 的 网 站 (或 虚拟 目录 ), 不 然 一 定 不 要 
把 网 站 (或 虚拟 目录 ) 赋 予 “ 目 录 浏 览 ” 权 限 。 


(2,3 安装 与 配置 SOL Server 2005 


12.3.1 安装 SOL Server 2005 


1. SQL Server 2005 版 本 综述 

和 SQL Server 2000 一 样 ,SQL Server 2005 也 推出 了 多 个 版 本 。 其 企业 版 本 只 能 安装 
在 服务 版 的 操作 系统 上 ,开发 版 则 可 以 安装 在 包括 Windows XP SP2 以 上 版 本 的 各 种 
Windows 操作 系统 上 ,另外 还 有 标准 版 工作 组 版 等 不 同 的 版 本 。 

SQL Server 2005 是 一 个 非常 庞大 的 体系 ,除了 必须 的 SQL Server Service、 客 户 端 操 
作 程序 外 ,还 提供 了 对 Visual Studio .NET 的 支持 、 商 业 职 能 等 功能 。 

SQL Server 2005 要 求 计 算 机 系统 至 少 有 512MB 的 内 存 、 处 理 器 在 Pentium 于 
600MHz 以 上 。 

在 真正 地 为 大 量 业 务 活动 提供 服务 的 信息 系统 中 ,为 保证 数据 库 管 理 系统 的 响应 能 力 
和 并 发 度 , 必 须 在 服务 器 上 安装 SQL Server 2005 的 服务 器 版 本 (企业 版 ) 。 

2. 安装 服务 器 版 SOL Server 2005 

要 向 服务 器 中 安装 SQL Server 2005 ,其 主要 过 程 如 下 。 

(1) 以 Administrator 用 户 身 份 登录 Windows Server。 

(2) 把 SQL Server 2005 光盘 放 到 服务 器 的 光驱 中 ,系统 会 自动 运行 。 如 果 光 盘 没 有 自 
动 运行 ,可 打开 资源 管理 器 , 单 击 光盘 上 的 Setup. exe 文件 ,启动 安装 程序 。 

(3) 安装 向 导 运 行 后 ,将 首先 弹出 【最终 用 户 许 可 协议 ] 对 话 框 ,如 图 12-24 所 示 。 只 有 
同意 软件 的 许可 协议 , 才 可 单 击 【下 一 步 ] 按 钮 ,继续 操作 。 
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(4) 接着 向 导 开始 检查 当前 服务 器 的 软件 环境 ,打开 [安装 必 备 组 件 ] 对 话 框 ,如 图 12-25 
所 示 。 此 时 单 击 【安装 按钮 ,向 导 开始 向 服务 器 中 安装 必 备 的 组 件 。 


最 终 用 户 许可 协议 


[CROSOFT 款 件 许可 条 款 
CRDSOFT SQL SERVER 2005 STANDARD 和 ENTERPRISE EDITION | 


Mi oft Ce 【 的 Jicrosof 
多 ee Ne 全 Rt 


SPT 和 上 和 全 《和 eatt SI Srer 0 
有 
+ 更 新 、 
* 补充 、 击 “ 实 装 ” 继 缀 。 
+ 基于 Internet 的 服务 和 
* 支持 服务 


如 果 确实 附带 有 其 他 伞 款 ， 则 其 他 他 款 应 适用 。 
v 


" 世 柯 委 了 和 和 了 


打印 P 取消 
图 12-24 SQL Server 软件 使 用 许可 协议 图 12-25 安装 必 备 组 件 


(5) 必 备 组 件 安装 完成 后 , 单 击 [ 下 一 步 ] 按 钮 ,向 导 会 扫描 当前 服务 器 的 硬件 配置 , 检 
查 当 前 的 服务 器 硬件 是 否 满足 要 求 。 图 12-26 显示 了 不 能 完全 满足 要 求 的 某 服务 器 的 警告 
性 信息 。 如 果 没 有 严重 错误 信息 , 则 单 击 [ 下 一 步 ] 按 钮 继续 。 


配置 检查 
请 等 竺 ， 正在 检查 系统 中 是 否 有 潜在 的 安装 问题 


@w 

详细 信息 iD) 

操作 

加 WI 服务 要 求 

加 esxL 要 求 

回 折 作 系统 最 低级 别 要 求 

加 操作 系统 Service Fack 亏 别 要 求 ， 
加 SQL Server 版 本 的 的 作 系统 兼容 性 
出 最低 硬件 要 求 

出 IIS 功能 要 求 

加 挂 起 的 重新 启动 要 求 

加 性 能 监 讽 器 计数 器 要 求 


节选 四。 
帮助 0 


:如 如 军 尝 如 如 如 如 如 | 入 


12-26 检测 服务 器 是 否 满足 配置 要 求 


注意 ; 如 果 只 有 警告 性 信息 , 则 不 影响 系统 的 继续 安装 。 
(6) 此 时 向 导 要 求 输入 用 户 姓 名 、 公 司 名 称 以 及 产品 序列 号 ,如 图 12-27 所 示 , 输 入 完 


毕 , 单 击 [下 一 步 ] 按 钮 。 


(7) 此 时 ,向 导弹 出 【要 安装 的 组 件 ] 对 话 框 ,可 选择 准备 安装 的 组 件 , 如 图 12-28 所 示 。 
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最 低 要 求 选中 SQL Server Database Services 组 件 , 通 常 要求 安 装 SQL Server Database 
Services 和 “工作 站 组 件 、 联 机 从 书 和 开发 工具 ”。 然 后 单 击 【 下 一 步 ] 按 钮 。 


穆 Wicrosoft SQL Server 2005 安装 程序 区 | 限 下 crosoft SQL Server 2005 安装 程序 


注册 信息 要 安装 的 组 件 
下 列 信息 将 对 您 安装 的 系统 进行 个 性 化 设置 。 请 迄 笃 要 安装 或 升级 的 址 件 。 


在 继续 换 作 之 前 ， 必 须 填写 “姓名 ” 宇 筷 。 “公司 ”字段 是 可 过 的 。 SQL Server Database Services G) 


站 各 四 ry sevice 


公司 多 ) 和 
J Chins Dyotificaion Services(Q) 
DIntegration Serviees D) 


口 工作站 担 件 、 联 机 全书 和 开发 工 具 @) 


Ci-s®)| [2 > 


图 12-27 输入 软件 序列 号 图 12-28 选择 要 安装 的 组 件 


注意 ; 如 果 在 【要 安装 的 组 件 】 对 话 框 中 单 击 右 下 角 的 按钮 [高 级 】, 则 可 以 打开 【功能 选 
择 】 对 话 框 ,此 时 可 以 进行 比较 具体 的 功能 选择 ,并 能 够 选择 安装 位 置 ,把 SQL Server 2005 
安装 到 其 他 磁盘 上 。 

(8) 向 导 要 求 确定 数据 库 的 实例 名 ,可 以 使 用 [默认 实例 了 ,也 可 以 自己 定义 新 的 [命名 
实例 】, 如 图 12-29 所 示 。 笔 者 建议 根据 自己 的 项 目的 情况 定义 新 实例 。 例 如 ,可 选择 【命名 
实例 有 单 选 按钮 ,然后 输入 新 的 实例 名 字 “MyBooK”。 最 后 单 击 【下 一 步 ] 按 钮 。 

(9) 向 导 要 求 确定 服务 账户 的 类 型 。 如 果 Windows 服务 器 不 在 域 中 , 则 选择 【使 用 内 
置 系统 账户 】 ,并 选择 [本 地 系统 ]。 如 果 Windows 服务 器 在 域 中 , 则 可 以 选择 [使 用 域 用 户 
账户 】, 并 设置 用 户 名 ,密码 , 选 定 域名 称 。 然 后 单 击 【下 一 步 ] 按 钮 ,如 图 12-30 所 示 。 


Server 2005 安装 程序 区 | 不 icrosoft SQL Server 2005 安装 程序 
实例 名 服务 账户 
悠 可 以 安装 默认 实说 也 可 以 指定 一 个 命名 实例 , 服务 账户 定义 和 登录 时 使 用 的 账 己 。 
| 
RN 


口 为 委 个 最 务 张 户 进行 自 定义 亿 ) 


OMUVRNT 


〇 年 名 实 网 则 


安装 结束 时 后 动 服务 
sa server ®) 口 st hreser 
口 st Server Meat 加 
Dinalysis Services (A) 


Esw >jL 了 |] Caam Ci-s®)] -sm wi |] 


12-29 ”确定 服务 器 实例 名 称 12-30 选择 DBMS 与 操作 系统 结合 的 
服务 账户 类 型 


312 


vt 


动态 网 站 设计 与 开发 (ASP. NET 版 ) 


(10) 向 导 要 求 选择 “身份 验证 模式 ”, 一 般 都 选择 [混合 模式 (Windows 身份 验证 和 
SQL Server 身份 验证 )】〗»。 如 果 选 定 了 混合 模式 , 则 需要 输入 系统 管理 员 (sa) 的 密码 。 密 码 
应 该 输入 两 次 ,并 牢记 ,如 图 12-31 所 示 。 然 后 单 击 【 下 一 步 ] 按 钮 。 


身份 验证 模式 
身份 验证 模式 指定 了 连接 S9L Server 时 使 用 的 安全 设置 。 


过 择 此 来 统 要 使 用 的 身份 验证 模式 。 


12-31 设置 DBMS 对 用 户 的 身份 验证 模式 


(11) 向 导 要 求 选择 “排序 规则 设置 ", 通 常 选 定 默 认 值 ,直接 单 击 【 下 一 步 ] 按 钮 。 接 着 
向 导 要 求 确定 “错误 和 使 用 情况 报告 设置 ”, 可 仍然 选 定 默认 值 ,直接 单 击 【下 一 步 ] 按 钮 。 

(12) 向 导 开 始 进 入 【准备 安装 ] 对 话 框 ,如 图 12-32 所 示 。 单 击 【安装 按钮 后 ,开始 安 
装 过 程 ,如 图 12-33 所 示 。 


个 三 crosoft SQL Server 2005 安装 程序 


谁 备 安装 
安装 程序 已 就 绪 ， 可 以 开始 安装 ， 


-A 
a 


erver 2005 安装 程序 


胆 安 将 以 下 组 件 : 


SQL Server Database Services 
库 服务 ， 复 制 ， 全 文 搜索 ) 


(数据 


， hnalysis Services 


TT 


图 12-32 准备 安装 组 件 图 12-33 正在 安装 组 件 


(13) 大 约 需 要 10 多 分 钟 ,文件 复制 和 注册 过 程 就 会 完成 。 

注意 : 如 果 SQL Server 2005 的 安装 盘 是 精简 版 本 的 ,上 述 安装 过 程 只 会 安装 SQL 
Server 2005 的 服务 器 端 数 据 库 和 容 户 端的 系统 配置 工具 ,并 没有 安装 图 形 化 的 界面 操作 软 
件 SQL Server 2005 Management Studio。 对 初学 者 来 讲 ,此 时 还 需要 安装 SQL Server 
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2005 Management Studio ,而 完整 的 企业 版 则 不 需要 单独 安装 此 软件 。 如 果 需 要 单独 安装 
SQL Server 2005 Management Studio, 则 需要 找到 SQLServer2005_SSMSEE. msi 文件 , 运 
行 安装 这 一 软件 ,为 网 管 提供 一 个 可 视 化 的 数据 库 管 理 界面 。 

3. SQL Server 2005 的 组 件 

完整 的 SQL Server 2005 数据 库 管理 系统 在 服务 器 端 ,客户 端 都 提供 大 量 的 工具 ,支持 
DBA 和 终端 用 户 开展 数据 库 维 护 、 数 据 智 能 分 析 等 活动 。 比 较 关 键 的 部 件 主要 有 以 下 
几 种 。 

1) 服务 器 端 组 件 

SQL Server 2005 的 服务 器 端 组 件 有 以 下 几 个 。 

(1) SQL Server 数据 库 引擎 用 于 进行 数据 库 建 设 、 管 理 和 保护 数据 等 核心 服务 ,能 够 
复制 .全文 搜索 以 及 管理 关系 数据 。 

(2) Analysis Services 包括 用 于 创建 和 管理 联机 分 析 处 理 ,以 及 数据 挖掘 应 用 程序 等 等 
工具 。 

(3) Report Services 用 于 各 类 报表 ,是 一 个 可 用 于 开发 报表 应 用 程序 的 可 扩展 平台 。 

(4) Integration Services 是 一 组 图 形 工具 和 可 编程 对 象 ,用 于 移动 .复制 和 转换 数据 。 

2) 客户 端 组 件 

SQL Server 2005 的 客户 端 组 件 有 以 下 几 个 。 

(1) Management Studio Express 是 一 个 集成 操作 环境 ,对 数据 库 的 所 有 直接 操作 都 可 
以 在 这 里 完成 。 

(2) Analysis Services 部 署 向 导 为 商业 智能 应 用 程序 提供 了 联机 分 析 处 理 和 数据 挖掘 
功能 ,能 够 实现 跨 多 个 应 用 系统 的 联机 分 析 。 

(3) SQL Server Business Intelligence Development Studio 是 一 个 集成 的 开发 环境 , 主 
要 用 于 开发 商业 智能 构造 , 它 包 括 一 些 项 目 模板 ,能 够 为 开发 特定 的 构造 提供 模板 
支持 。 

3) 配置 工具 

SQL Server 的 客户 端 还 提供 了 很 多 配置 工具 ,其 中 比较 重要 的 是 SQL Server 
Configuration Manager, 它 能 够 为 SQL Server 服务 .SQL Server 服务 的 网 络 连接 协议 、 客 
户 端 协议 .客户 端 别名 管理 等 提供 基本 的 配置 管理 工具 。 

注意 ; VS2008 安装 的 SQL Server 是 一 个 精简 版 本 ,不 包含 上 述 工具 。VS2008 通过 自 
带 的 【服务 器 资源 管理 器 】 面 板 连 接 SQL Server 2005 数据 库 , 并 实施 简单 的 数据 操作 。 如 
果 需 要 完成 复杂 的 数据 备份 .数据 格式 转换 等 活动 ,就 需要 上 述 组 件 的 支持 。 


12.3.2 SOQL Server 2005 Management Studio 


1. 启动 Microsoft SQL Server Management Studio 

启动 已 经 正常 安装 SQL Server 2005 的 服务 器 后 ,选择 菜单 【开始 】- 江 所 有 程序 -~ 
Microsoft SQL Server 2005->SQL Server Management Studio, 系 统 将 弹出 如 图 12-34 所 示 
的 启动 界面 。 

选择 [Windows 身份 验证 方式 ,然后 单 击 【连接 按钮 ,系统 将 启动 Microsoft SQL 
Server Management Studio, 进 入 到 对 SQL Server 2005 的 管理 状态 。 
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同 连 按 到 服务 器 


$6L serverzo0s 


图 12-34 启动 Management Studio 


注意 : 如 果 选 择 *SQL Server 身份 验证 ”, 则 必须 正确 地 输入 SQL Server 数据 库 实例 的 
用 户 名 和 密码 。 例 如 用 户 名 “sa”, 密 码 则 是 安装 DBMS 时 设置 的 密码 。 
系统 正常 启动 后 ,操作 界面 如 图 12-35 所 示 。 


文件 四 ” 编 入 四、 视 目 四 
了 Ha 查 询 中 站 蕊 过 名 及 本 如 苇子 
描 要 


图 12-35 Microsoft SQL Server Management Studio Express 的 主 界面 


2. Microsoft SQL Server Management Studio Express 界面 操作 

Microsoft SQL Server Management Studio Express 操作 界面 分 为 两 部 分 , 左 侧 为 【对 
象 资源 管理 器 面板 ,采用 了 树 形 层次 结构 ,如 图 12-35 所 示 。 

从 图 12-36 可 看 出 ,此 树 形 结构 层次 依次 为 数据 库 服 务 器 实例 名 (BNUMAXL) 王 数据 
库 一 系统 数据 库 一 具体 数据 库 名 称 一 表 名 一 列 名 等 层次 ,或 者 为 数据 库 服务 器 实例 名 
(CBNUMAXL) 一 安全 性 ~ 登录 名 一 具体 的 登录 组 名 (或 具体 的 登录 名 ) 等 层次 。 

在 SQL Server 的 对 象 资源 管理 器 中 能 够 对 数据 库 进 行 各 种 层次 的 管理 , 即 在 这 个 树 状 
结构 图 中 ,以 鼠标 单 击 项 目 左 侧 的 小 加 号 可 以 展开 这 个 项 目 ,如 果 项 目 左 侧 为 小 减 号 ,表示 
这 个 项 目 已 经 展开 , 单 击 小 减 号 ,可 以 折 双 项目 。 

Microsoft SQL Server Management Studio Express 中 最 常见 的 操作 是 以 鼠标 右 击 某 
个 对 象 ,系统 将 弹出 一 个 快捷 菜单 。 在 快捷 菜单 中 选择 自己 需要 的 操作 即 可 启动 这 个 功能 ， 
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如 图 12-37 所 示 。 


Bicrosoft SQL Server Nanagenent Studio Express 
文件 四 ”编辑 到 ) 视图 WW) 工具 四 窗口 四 社区 加 帮助 咱 
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黄 要 
当 县 二 上 了 且 3 号 了 量 天 加 |- 
SB BAXL (SQL Server 9.0.1399 - BMAXL\ 
国 登录 名 


了 UNIL\ 安 全 性 \ 登 录 名 


名 称 

优 BMAXL\SQLS erver2005MSFTEVs er$BWUNAXLS. 
各 BNUMAXL\SQLServer2005mSSQLUs er$BWUNAXLS, 
各 BWMAXL\SQLServer2005SQLAgentUser$ENMA 
岗 BUTLTINWAdninistrators 
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Microsoft SQL Server Wanagement Studio Express 画 避风 
文件 C) 编辑 G) 视图 外 工具 QD) 究 口 人 D) 社区 CC) 帮助 
习 和 有 测 W) 站 区 局 园 忆 四 要 孩子 = 


还 原文 件 和 文件 组 @) 
刷新 中 


图 12-37 操作 数据 库 对 象 


3. Microsoft SQL Server Management Studio Express 的 查询 界面 

众所周知 ,关系 数据 库 的 通用 管理 语言 是 SQL 语言 ,因此 SQL Server 2005 也 一 定 提 
供 对 SQL 语言 的 支持 。 在 Microsoft SQL Server Management Studio Express 中 ,进入 到 
SQL 语言 运行 界面 的 方法 为 : 单 击 Microsoft SQL Server Management Studio Express 主 
界面 的 工具 栏 [新 建 查询 ] 按 钮 ( 见 图 12-38), 则 进入 到 运行 SQL 语句 的 界面 ,如 图 12-39 所 
示 。 用 户 可 在 右 侧 的 窗口 中 直接 输入 SQL 语句 。 

在 如 图 12-39 所 示 的 查询 界面 中 ,可 以 在 “1” 所 标记 的 区 域 中 选择 当前 数据 库 , 在 “2” 所 
标记 的 区 域 中 直接 输入 SQL 语句 。 单 击 区 域 “2” 顶 上 的 按钮 *V "可 以 检测 SQL 语句 是 否 
存在 语法 问题 ; 单 击 区 域 “2” 顶 上 的 按钮 [ 1! 执行 ] 则 可 以 执行 这 个 SQL 语句 ,并 把 执行 结果 
在 区 域 “3” 显 示 出 来 。 


@) 视图 WD I 具名 从 D 思 芭 区 加 
ET 


~ 里 X 。 贡 要 


EE 


国 数据 库 


BWAXL\ 数 舌 库 


12-38 启动 查询 生成 器 
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12-39 查询 界面 示意 图 


4. 附加 数据 库 

独立 的 SQL Server 数据 库 文件 无 法 被 Web 应 用 程序 使 用 。 也 就 是 说 ,只 把 开发 过 程 中 创 
建 的 SQL Server 文 件 复制 到 服务 器 上 是 不 能 发 挥 作 用 的 ,必须 把 数据 库 附加 到 服务 器 上 的 
SQL Server 2005 系统 中 ,才能 被 SQL Server 2005 引擎 驱动 ,为 Web 应 用 程序 提供 数据 支持 。 

对 于 已 经 存在 的 SQL Server 2005 数据 库 文件 ,可 以 利用 Microsoft SQL Server Management 
Studio 中 的 “附加 数据 库 ? 功 能 把 这 个 数据 库 附加 到 SQL Server 2005 系统 中 ,由 SQL Server 
2005 系统 驱动 已 经 存在 的 数据 库 , 实 施 操作 ,如 图 12-40 所 示 。 具 体操 作 过 程 如 下 。 

首先 ,从 左 侧 的 [对象 资源 管理 器 了 面板 树 状 结构 中 找到 【数据 库 】, 然 后 右 击 【 数 据 库 】。 

其 次 ,再 从 弹出 的 快捷 菜单 中 选择 【附加 】 ,系统 将 打开 一 个 附加 数据 库 的 对 话 框 。 

再 次 ,把 已 经 复制 到 服务 器 上 的 数据 库 文件 (扩展 名 为 mdf 的 文件 ) 添 加 到 对 话 框 中 。 

最 后 , 单 击 【 确 定 ] 按 钮 即 可 。 
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12-40 ”向 SQL Server 2005 附加 数据 库 


注意 ; 一 个 SQL Server 2005 数据 库 至 少 由 两 个 文件 构成 ,一 个 是 扩展 名 为 mdf 的 数 
据 文件 , 另 一 个 是 扩展 名 为 log 的 日 志文 件 。 在 附加 数据 库 前 ,一 定 要 检查 数据 库 的 文件 是 
否 完整 ,否则 可 能 导致 附加 数据 库 失 败 。 


(12.4 发 布 与 配置 应 用 系统 


要 把 一 个 Web 应 用 系统 发 布 到 专用 的 Web 服务 器 上 ,主要 包括 两 个 关键 部 分 : 其 一 
是 把 后 台数 据 库 迁 移 到 Web 服务 器 上 ; 其 二 是 编译 并 发 布 ,并 把 发 布 成 功 的 应 用 系统 迁移 
到 Web 服务 器 ,进行 必要 的 参数 调整 。 


12.4.1 在 Web 服务 器 上 配置 后 台数 据 库 


1. 从 开发 用 计算 机 上 复制 数据 库 

要 从 开发 用 的 计算 机 上 复制 数据 库 ,必须 先 找到 数据 库 文件 。 一 般 情况 下 ,数据 库 文件 
要 么 被 放 在 项 目的 App_Data 文件 夹 下 ,要 么 被 存放 在 SQL Server 2005 的 系统 文件 夹 中 。 
例如 ,笔者 的 SQL Server 2005 安装 在 E 盘 的 Program Files 文件 夹 中 ,那么 所 有 的 数据 库 
文件 都 默认 存储 在 E:\Program Files\Microsoft SQL Server\MSSQL. 1\MSSQL\Data 文 
件 夹 下 。 当 然 ,也 可 以 借助 计算 机 的 搜索 功能 ,搜索 扩展 名 为 mdf 的 文件 的 存储 位 置 。 总 
之 ,通过 各 种 手段 ,找到 SQL Server 数据 库 文件 。 

把 所 需 数 据 库 的 两 个 文件 (数据 文件 mdf 和 日 志文 件 log) 复 制 出 来 ,然后 复制 到 服务 
器 的 适当 文件 夹 中 。 

注意 : 如 果 开 发 用 的 计算 机 上 安装 的 是 VS2008 自 带 的 SQL Server Express 版 本 , 则 
复制 数据 库 文 件 时 必须 关闭 [服务 器 资源 管理 器 面板 中 的 【数据 连接 】, 其 至 关闭 整个 
VS2008 开发 工具 。 如 果 开发 用 的 计算 机 上 安装 的 是 独立 的 SQL Server 2005 的 开发 版 本 ， 
则 必须 在 复制 数据 库 文件 前 利用 SQL Server 2005 自 带 的 SQL Server Configuration 
Manager 工具 停止 SQL Server 2005 服务 器 ,然后 才 可 复制 数据 库 的 相关 文件 。 
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2. 把 数据 库 附加 到 Web 服务 器 的 SQL Server 2005 系统 中 

首先 ,启动 服务 器 上 的 Microsoft SQL Server 2005 Management Studio, 登录 到 “数据 
库 引 擎 "状态 。 

其 次 ,展开 [对象 资 源 管理 ] 中 的 树 状 结构 , 右 击 【 数 据 库 】, 从 快捷 菜单 中 选择 [附加 】, 在 
随后 弹出 的 对 话 框 中 选择 刚刚 复制 来 的 数据 库 文件 。 

最 后 ,通过 单 击 【确定 按钮 确认 操作 ,完成 数据 库 的 “附加 ?工作 。 

数据 库 附 加 工作 完成 后 ,可 在 Microsoft SQL Server 2005 Management Studio 打开 刚 
刚 附 加 的 数据 库 , 检 查 数据 库 中 的 数据 表 和 数据 记录 ,保证 附加 过 来 的 数据 库 符 合 项 目的 
要 求 。 


12.4.2 发 布 Web 应 用 系统 


1. 发 布 网 站 的 概念 和 作用 

ASP.NET 为 应 用 程序 的 使 用 提供 了 两 种 编译 模式 : 其 一 是 动态 编译 ,其 二 是 预 编译 。 
所 谓 动态 编译 ,就 是 把 网 页 的 C# 源 码 和 界面 设计 一 起 被 放 在 Web 服务 器 上 。 在 网 页 第 一 
次 被 访问 时 ,网 页 中 的 C# 源 码 被 编译 成 DLL 文档 ,而 且 随 着 应 用 程序 的 更 新 ,网 页 的 源码 
可 以 不 断 地 被 修改 .编译 。 所 谓 预 编译 ,就 是 把 项 目 中 App_Code 文件 夹 下 的 所 有 C# 代 码 
(cs 文档 ) 等 编译 为 动态 链接 库 文件 (DLL) ,并 能 在 预 编译 过 程 中 发 现 一 切 错误 ,并 最 终 形 
成 执行 效率 较 高 的 ,依托 于 CLR 的 伪 码 文件 。 在 预 编译 模式 下 ,用户 访问 Web 服务 器 将 直 
接 使 用 伪 码 文件 ,而 不 必 重 新 编译 。 对 比 这 两 种 状态 ,动态 编译 比较 适宜 于 程序 开发 ,调试 
阶段 。 而 预 编 译 比较 适宜 大 型 网 站 的 稳定 运营 阶段 。 

对 比 上 述 两 种 模式 ,由 于 预 编译 得 到 的 成 品 中 不 包含 Web 应 用 程序 的 源 代码 ,对 于 保 
护 Web 应 用 程序 的 版 权 ,程序 安全 性 和 网 站 的 运行 效率 都 很 有 意义 。 因 此 ,当前 绝 大 多 数 
的 动态 网 站 都 采用 预 编 译 模式 发 布 Web 应 用 程序 ,这 一 工作 也 称 为 “发 布 网 站 ”。 其 基本 过 
程 是 对 现 有 的 项 目 进行 预 编译 并 把 编译 后 的 伪 码 输出 到 指定 位 置 。 虽 然 VS2008 提供 了 多 
种 目标 位 置 供 发 布 时 选用 ,但 笔者 认为 发 布 到 本 地 计算 机 上 的 一 个 空 文件 夹 是 最 为 安全 和 
效率 最 高 的 方式 。 

由 于 一 个 Web 应 用 项 目 进入 实用 化 阶段 的 前 提 条 件 就 是 保证 程序 的 正确 性 和 可 用 性 ， 
因此 * 发 布 网 站 ”的 首要 任务 就 是 在 开发 用 的 计算 机 上 


实现 应 用 程序 的 发 布 ,保证 形成 一 套 完整 的 .没有 错误 
加 sams | 的 .及 时 响应 的 系统 。 
+ en 2. 在 本 地 计算 机 发 布 网 站 
;| aaam- VS2008 为 发 布 网 站 提供 了 便利 的 手段 ,因此 在 开 
| | 王 汗 引发 用 的 计算 机 上 发 布 本 地 应 用 程序 非常 简单 。 其 基本 
+ 过 程 如 下 。 
| 1 清理 并 生成 项 目 , 做 好 准备 工作 
¢ 8 打开 一 个 已 经 完成 的 项 目 ,首先 在 [解决 方案 资源 
re 管理 器 了 面板 中 右 击 【解决 方案 】, 从 弹出 的 快捷 菜单 中 
选择 [清理 解决 方案 】, 如 图 12-41 所 示 。 
2-41 重新 生成 解决 方案 在 清理 解决 方案 完成 后 ,再 选择 【重新 生成 解决 
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方案 】。 

如 果 全 部 解决 方案 都 能 够 成 功 生成 , 则 表示 本 网 站 中 已 经 不 存在 语法 错误 ,能 够 顺利 
运行 。 

2) 发 布 项 目 , 形 成 产品 

右 击 项 目 名 称 ,在 弹出 的 快捷 菜单 中 选择 [发 布 】, 则 打开 [发 布 Web] 对 话 框 , 如 图 12-42 
所 示 。 


目标 位 置 (http:、ftp: 或 磁 总 路 径 )(D 


癌 用 本 地 副本 营 尝 开 配 的 文件 (R) 
发 布 前 昼 除 所 有 现 有 文件 (D) 


复制 

司 仅 陆运 行 此 应 用 生 序 所 雪 的 文件 ( 山 
所 有 项 目 文件 () 

DD 源 项 目 文件 实 中 的 所 有 文件 (入 

闭 包 会 App_Data 文件 夫 中 的 文件 由 


图 12-42 【发 布 Web] 对 话 杠 


首先 ,设置 项 目的 发 布 位 置 ,建议 设置 为 本 地 磁盘 上 的 一 个 空 文件 夹 。 

其 次 ,可 以 根据 需求 在 图 12-42 所 示 的 界面 中 进行 一 些 选项 设置 。 

最 后 , 单 击 【发 布 ] 按 钮 ,启动 发 布 过 程 。 

发 布 完毕 ,将 会 在 指定 的 文件 夹 中 形成 整个 项 目的 最 终 产品 。 

3. 检测 并 配置 Web 服务 器 

在 本 地 计算 机 上 完成 “发 布 网 站 ”的 工作 ,得 到 项 目的 成 品 后 ,就 需要 把 项 目 迁 移 到 
Web 服务 器 上 了 ,具体 操作 如 下 。 

1) 检测 Web 服务 器 的 .NET Framework 版 本 

基于 .NET 3. 5 版 本 开发 的 Web 应 用 程序 ,当然 需要 .NET Framework 3. 5 的 支持 。 
因此 在 正式 发 布 ASP .NET 3. 5 的 应 用 程序 系统 前 ,应 该 检查 Web 服务 器 的 .NET 
Framework 的 版 本 号 ,特别 是 以 Windows Server 2003 作为 操作 系统 的 Web 服务 器 ,一 定 
要 补充 安装 .NET Framework 3. 5 框架。 

利用 菜单 【控制 面板 革 拭 印 载 或 更 新 程序 ,打开 系统 [ 印 载 或 更 新 程序 】 窗 口 ,检查 是 否 
存在 “Microsoft .NET Framework 3.5” 项 。 如 果 不 存在 此 项 , 则 需要 在 服务 器 上 安装 此 框 
架 , 如 图 12-43 所 示 。 

或 者 ,利用 IIS 的 信息 服务 管理 器 ,检查 当前 的 Web 服务 器 中 已 经 安装 的 .NET 
Framework 的 最 高 版 本 号 ,如 图 12-44 所 示 。 

例如 ,图 12-44 所 示 的 IIS 6.0 的 .NET Framework 版 本 号 就 不 符合 要 求 ,需要 补充 安 
装 .NET Framework 3.5。 而 图 12-43 所 示 的 IIS 7.0 中 的 .NET Framework 版 本 号 就 达到 
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= 
GO , “rs , Bs , Br 四 加 | P| 
pe 种 载 或 更 改 程序 
查看 已 安 笑 的 更 新 若 和 要务 款 企 序 , 请 从 列表 中 将 其 选中 , 然后 单 去 “名 载 “更 改 ”或 “ 修 

加 打 S 关 辣 Windows 3 能 复 。 
给 织 " #» © 
包谷 了 发 布 者 
加 Crystal Reports Basic Simplifed Chinese Language Pac.. Business Objec 
可 Dreamweaver8 国 
ESET NOD32 Antiviru ESET spolsr,. | 
是 Microsoff ,NET Compact Framework 2.0 SP2 Microsoi 

licrosoft NET Compact Famework 3.5 Mi 
螺 Microsok NET Framework 4 Client Profile Microsoft CorF 
回 Microsoft Device Emulator 3.0 版 - 简体 中 文 Microsoft CorF 
站 Microsop Document Explorer 2008 Microsoft Corp 
各 Microsoft Document Explorer 2008 语言 包 - 简体 中 文 Microsoft CorF 
D3 Microsoft Office 2003 Web Components Microsoft Corp ~ 
4 
于 | 当前 安装 的 程序 总 大 小 143 GB 
Ko 4 安 直 可 


图 12-43 ”利用 [ 印 载 或 更 新 程序 ] 功 能 检查 已 安装 的 .NET Framework 版 本 


网 站 属性 


RM | 性 能 | IST 印加 | 主 上 录 | 
目录 Rh 性 | TTP 头 | 自 定 久 鱼油 | 服务 


Eat Cohan 
[CC 本 |]_ 册 | |_ 枫 
12-44 通过 IIS 6.0 的 信息 服务 管理 器 检查 .NET Framework 版 本 


了 运行 ASP.NET 3. 5 应 用 程序 的 要 求 。 

2) 为 不 满足 版 本 要 求 的 Web 服务 器 安装 高 版 本 .NET Framework 

如 果 当 前 服务 器 中 已 安装 的 .NET Framework 版 本 不 能 满足 当前 ASP.NET 应 用 程序 
的 需要 , 则 需要 补充 安装 满足 版 本 要 求 的 .NET Framework。 

为 此 ,可 找到 Visual Studio 2008 的 安装 盘 ,在 服务 器 上 启动 VS2008 安装 程序 ,然后 从 
系统 提供 的 [选择 安装 组 件 ] 窗 体 中 选中 .NET Framework 3. 5 框架 ,执行 安装 过 程 ,把 
.NET Framework 3. 5 框架 安装 到 服务 器 上 。 

注意 : 在 这 一 过 程 中 不 需要 安装 VS2008 的 开发 工具 和 SQL Server 2005 数据 库 系统 ， 
因为 VS2008 自 带 的 SQL Server 2005 是 开发 版 的 DBMS ,难以 满足 业务 活动 中 并 发 处 理 的 
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要 求 。 

4. 把 应 用 程序 发 布 到 Web 服务 器 上 

首先 ,把 储存 “发 布 网 站 ”产品 的 整个 文件 夹 从 本 地 计算 机 复制 到 服务 器 上 ,并 存储 在 服 
务 器 上 独立 的 文件 夹 中 。 

其 次 ,启动 服务 器 上 的 【Internet 信息 服务 (IIS) 管 理 器 】 ,新 建站 点 ,新 站 点 要 具备 “ 执 
行 " 和 *“ 读 取 ” 的 权限 ,并 让 新 站 点 的 物理 路 径 指向 服务 器 上 的 产品 文件 夹 。 如 图 12-45 所 
示 , 新 建 了 一 个 网 站 [教学 系统 】。 


GO wc 


文件 昌 。 视 加 VV) 。 帮 动 (H) 


[一 全 | MAXLPC 主页 


@ befauk Wel + ra 

@ HE% > 击 
JNET 策 尝 .NET 错误 页 

9 名 
JNET 全 球 化 .NET 授权 规 

则 
ra 
3 岛 


,NET 信任 级 SMTP 电子 
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第 三 ,检查 产品 文件 夹 中 的 App_Data 下 是 否 有 数据 库 , 如 果 有 ,也 把 这 个 数据 库 附加 
到 SQL Server 2005 系统 中 。 

第 四 ,检查 服务 器 上 SQL Server 2005 服务 器 的 名 称 ,并 记录 下 来 。 然 后 到 产品 文件 夹 
中 ,找到 Web.config 文件 ,用 记事 本 打开 它 。 从 中 查找 数据 库 连 接 字 符 串 过 connectionStrings， 
把 其 中 的 SQL Server 服务 器 名 称 由 “sqlexpress” 修 改 为 当前 的 SQL Server 2005 服务 器 的 
名 称 。 从 而 保证 当前 的 Web 应 用 系统 能 够 访问 Web 服务 器 上 的 SQL Server 2005 数据 库 
系统 。 

第 五 ,把 产品 的 主页 文件 名 记录 下 来 ,把 它 设置 为 当前 网 站 的 默认 文档 。 

最 后 ,利用 本 机 或 其 他 的 计算 机 访问 本 网 站 ,检查 系统 的 运行 效果 。 


假 考题 


1. 什么 是 IIS? 其 含义 和 功能 是 什么 ? 

2. 为 了 保障 Web 服务 器 的 安全 性 ,应 该 如 何 配 置 IS? 

3. 什么 是 虚拟 目录 ? 设置 虚拟 目录 对 于 MIS 有 什么 意义 ? 

4. 如 何 限定 某 些 计算 机 不 能 访问 指定 虚拟 目录 ? 

5. SQL Server 2005 的 Management Studio 工具 有 什么 用 途 ? 
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6. 如 何 检查 当前 Web 服务 器 的 .NET Framework 的 版 本 号 ? 
7. 如 何 把 一 个 SQL Server 2005 的 数据 库 文件 附加 到 SQL Server 2005 系统 中 ? 
8. 如 何 才能 把 一 个 Web 应 用 系统 发 布 到 专用 Web 服务 器 上 ? 


仁 机 实 训 亚 


在 Windows 2000/XP/2003 下 安装 IIS, 并 完成 以 下 配置 与 测试 任务 。 

(1) 利用 还 及 “http://127.0.0.1/” 测 试 IIS 的 安装 情况 。 

(2) 在 IIS 下 设置 虚拟 目录 cs, 使 之 指向 EE 盘 上 的 实际 文件 夹 E:\xscs, 分 别 赋予 “ 读 
取 ”“ 写 入 ”“ 目 录 浏 览 ” 权 限 ,然后 在 下 浏览 器 地 址 栏 输入 “http://127. 0. 0. 1/cs” ,检查 
其 效果 。 

(3) 在 JIIS 下 设置 虚拟 目录 jx, 使 之 指向 EE 盘 上 的 实际 文件 夹 下;\xscs, 分 别 赋予 “ 读 
取 ”“ 执 行 脚本 ”权限 ,并 设置 此 虚拟 目录 的 默认 文档 为 index. aspx, 在 下 浏览 器 地 址 栏 输 
和 人 “http://127.0.0.1/jx/ 网 页 文件 全 名 ”, 检 查 其 效果 。 

(4) 检查 当前 Web 服务 器 的 .NET Framework 版 本 。 如 果 当 前 Web 服务 器 的 .NET 
Framework 版 本 不 能 满足 要 求 , 则 更 新 此 Web 服务 器 的 .NET Framework 版 本 。 

(5) 把 第 5 章 设计 的 “销售 信息 系统 数据 库 ” 复 制 到 Web 服务 器 上 ,利用 Microsoft 
SQL Server Management Studio 工具 完成 “附加 ”数据 库 的 工作 ,使 * 销 售 信息 系统 数据 库 ” 
成 为 Web 服务 器 上 SQL Server 2005 数据 库 系 统 的 组 成 部 分 ,能 够 被 这 个 DBMS 驱动 和 
控制 。 

(6) 在 开发 所 用 的 计算 机 上 以 本 地 发 布 的 方式 发 布 第 6 章 或 第 7 章 的 项 目 。 

(7) 把 已 经 发 布 的 项 目 从 开发 用 的 计算 机 中 迁移 到 Web 服务 器 上 。 然 后 ,测试 该 项 目 
在 Web 服务 器 上 的 运行 情况 ,并 根据 运行 中 反馈 的 问题 不 断 优化 和 调整 Web 服务 器 。 


Do io 
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